javascript – Typescript:使用let(最佳实践)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – Typescript:使用let(最佳实践),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1592字,纯文字阅读大概需要3分钟。
内容图文
![javascript – Typescript:使用let(最佳实践)](/upload/InfoBanner/zyjiaocheng/810/8fe2e546920e44d5999ea71f7e594f58.jpg)
我正在使用TypeScript而且我是新用的,所以我有一个关于声明变量的问题.
当我们声明一个变量时,我们使用let name:type = value.好吧,我总是分配变量的类型:如果我想要一个String我声明为字符串,与booleans和数字相同.我看到任何类型的变量的类型.
问题是:如果我将变量声明为数字,则必须使用let myNumber:number = 23;?有必要说类型是一个数字?
如果我不这样做,并且执行typeOf(myNumber)它返回数字,但对于TypeScript是数字还是任何?
最好的做法是在为变量赋值时始终设置类型,或者它不重要?
解决方法:
Typescript将避免使用任何类型的变量.在tsconfig.json中将选项noImplicityAny设置为true时,如果不指定类型,它甚至会给出错误,而Typescript只能将类型设置为any.
一般来说,当你在你的例子中指定一个类型时…
let myNumber: number = 23;
…你明确地设置了类型.这意味着您清楚地传达了使此变量成为数字的意图.分配非数字值时,您将收到错误.使用显式类型声明所有变量没有任何问题,因为这只会提高代码的清晰度.
另一种选择是隐式输入变量.只有在声明时为变量赋值时才能执行此操作:
let myNumber = 23;
由于您为变量指定了数字文字,因此Typescript可以推断出变量的类型,并将其视为数字.在某些情况下,覆盖推理是有用的,例如对于联合类型:
let myNumberOrText: number | string = 23;
如果noImplicitAny设置为true,则禁止任何隐式输入.所以…
let myAny = { FirstName: "John", LastName: "Doe" };
…会导致错误,因为它会隐式输入任何错误.仍然允许显式版本.所以你可以写…
let myAny: any = { FirstName: "John", LastName: "Doe" };
…虽然在Typescript中你最好声明一个类或接口并用它来输入(假设你已经声明了一个Person类型):
let myPerson: Person = { FirstName: "John", LastName: "Doe" };
Typescript的重点是向JavaScript引入静态类型.如果您使用类型any声明变量,那么静态类型将无法获得优势,您可以使用纯JavaScript.
内容总结
以上是互联网集市为您收集整理的javascript – Typescript:使用let(最佳实践)全部内容,希望文章能够帮你解决javascript – Typescript:使用let(最佳实践)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。