今天来介绍一下 TypeScript 的一些较新的功能和进展,这些是我在日常工作中经常在用的功能。
创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站制作、成都网站建设、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的清苑网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!
Typescript 中可以通过构造函数的参数直接定义属性,我们来先看早期的做法:
- class Note {
- public title: string;
- public content: string;
- private history: string[];
- constructor(title: string, content: string, history: string[]) {
- this.title = title;
- this.content = content;
- this.history = history;
- }
- }
采用 ts 中简写的语法:
- class Note {
- constructor(
- public title: string,
- public content: string,
- private history: string[]
- ){
- // 这里不用在写 this.title = title
- }
- }
它可能看上去不像是有属性的类,但它确实有,利用的是 Typescript 提供的简写形式 — 用构造函数的参数直接定义属性。
这个简写语法做了很多:
??其实没啥意思,就是Nullish Coalescing (空值合并)。听起来有点懵,我们直接上代码
- const i = undefined
- const k = i ?? 5
- console.log(k) // 5
- // 3.9.2编译
- const i = undefined;
- const k = i !== null && i !== void 0 ? i : 5;
- console.log(k); // 5
这个时候你肯定是想说了这样不就完了吗?
- let k = i || 5
虽然这样也用,但是你不觉得很不严谨吗?如果i = 0呢?
TypeScript 3.8 将支持 ECMAScript 私有字段,千万别和 TypeScript private 修饰符 混淆。
这是在 TypeScript 中具有私有类字段的类:
- class Animal {
- #name: string;
- constructor(theName: string) {
- this.#name = theName;
- }
- }
在private关键字之上使用私有类字段的区别在于前者有更好的运行时保证。用private关键字声明的 TypeScript 字段将在编译后的JavaScript代码中成为常规字段。另一方面,私有类字段在编译后的代码中仍然是私有的。
试图在运行时访问私有类字段将导致语法错误。我们也使用浏览器开发工具也检查不了私有类字段。
有了私有类字段,我们终于在JavaScript中得到了真正的隐私。
命名元组类型适需要 TypeScript 4.0及以上版本才能使用,它极大的改善了我们的开发体验及效率,先来看一个例子:
- type Address = [string, number]
- function setAddress(...args: Address) {
- // some code here
- console.log(args)
- }
当我们这样定义函数入参后,在使用函数时,编辑器的智能提示只会提示我们参数类型,丢失了对参数含义的描述。
为了改善这一点,我们可以通过 Labeled tuple types,我们可以这样定义参数:
- type Address = [streetName: string, streetNumber: number]
- function setAddress(...args: Address) {
- // some code here
- console.log(args)
- }
这样,在调用函数时,我们的参数就获得了相应的语义,这使得代码更加容易维护。
自 ES6 开始,我们就可以通过模板字面量(Template Literals)的特性,用反引号来书写字符串,而不只是单引号或双引号:
- const message = `text`;
正如 Flavio Copes 所言,模板字面量提供了之前用引号写的字符串所不具备的特性:
模板字面量类型和 JavaScript 中的模板字符串语法完全一致,只不过是用在类型定义里面:
- type topBottom = "top" | "bottom"
- type leftRight = "left" | "right"
- type Position = `${topBottom }-${leftRight }`
当我们定义了一个具体的字面量类型时,TypeScript 会通过拼接内容的方式产生新的字符串字面量类型。
TypeScript为你提供了一组实用类型,让你在现有类型的基础上构建新的类型。有许多实用类型涵盖了不同的情况,例如选择类型属性来复制,大写字母,或使所有的属性都是可选的。
下面是一个使用 Omit工具的例子,它复制了原始类型的所有属性,除了我们选择不包括的那些。
- type User = {
- name: string
- age: number
- location: string
- }
- type MyUser = Omit
上面这些就是我工作经常使用的一部分,另外一些后面在分享,就这?
分享题目:这六个TS新特性经常用到,用了之后我再也离不开它!
转载来于:http://www.csdahua.cn/qtweb/news7/23057.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网