位置: 编程技术 - 正文

TypeScript Type Innference(类型判断)

编辑:rootadmin

推荐整理分享TypeScript Type Innference(类型判断),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

TypeScript 是微软开发的 JavaScript 的超集,TypeScript兼容JavaScript,可以载入JavaScript代码然后运行。TypeScript与JavaScript相比进步的地方 包括:加入注释,让编译器理解所支持的对象和函数,编译器会移除注释,不会增加开销;增加一个完整的类结构,使之更新是传统的面向对象语言。

为什么会有 TypeScript&#;

JavaScript 只是一个脚本语言,并非设计用于开发大型 Web 应用,JavaScript 没有提供类和模块的概念,而 TypeScript 扩展了 JavaScript 实现了这些特性。TypeScript 主要特点包括:

TypeScript 是微软推出的开源语言,使用 Apache 授权协议

TypeScript 是 JavaScript 的超集.

TypeScript 增加了可选类型、类和模块

TypeScript 可编译成可读的、标准的 JavaScript

TypeScript 支持开发大规模 JavaScript 应用

TypeScript 设计用于开发大型应用,并保证编译后的 JavaScript 代码兼容性

TypeScript 扩展了 JavaScript 的语法,因此已有的 JavaScript 代码可直接与 TypeScript 一起运行无需更改

TypeScript 文件扩展名是 ts,而 TypeScript 编译器会编译成 js 文件

TypeScript 语法与 JScript .NET 相同

TypeScript 易学易于理解

语法特性

类 Classes

接口 Interfaces

模块 Modules

类型注解 Type annotations

编译时类型检查 Compile time type checking

Arrow 函数 (类似 C# 的 Lambda 表达式)

JavaScript 的 TypeScript 的区别

TypeScript Type Innference(类型判断)

TypeScript 是 JavaScript 的超集,扩展了 JavaScript 的语法,因此现有的 JavaScript 代码可与 TypeScript 一起工作无需任何修改,TypeScript 通过类型注解提供编译时的静态类型检查。TypeScript 可处理已有的 JavaScript 代码,并只对其中的

TypeScript 代码进行编译。

在这一节,我们将介绍TypeScript中的类型推断。我们将会讨论类型推断需要在何处用到以及如何推断。

基础

在TypeScript中,在几个没有明确指定类型注释的地方将会使用类型推断来提供类型信息。

var x = 3;

变量"x"的值被推断为number。这种推断发生在变量或者成员初始化、设置参数默认值、决定函数返回类型的时候。

最佳公共类型

当需要从多个表达式中进行类型推断的时候,这些表达式的类型将会用来推断出一个"最佳公共类型"。例如:

var x = [0, 1, null];

要想推断出什么例子中"x"的类型,我们需要考虑每个数组元素的类型。这里,我们给出了两个数组类型的选择:number和null。最佳公共类型算法要求考虑到所有候选的类型,并选择出与所有候选类型兼容的类型。(这里的类型可为Array<number>)

由于最佳公共类型是从提供的候选类型中选择的,有些情况下,候选类型共享一个共同类型,但没有任何一个类型是所有候选类型的父类型。例如:

理想情况下,我们可能希望zoo被推断为Animal[]类型,但是因为数组中没有任何对象是严格的Animal类型,我们便不能做出推断。为了解决这个问题,当不能推断出所有候选类型的父类型的时候,我们需要明确的提供类型。

当没有最佳公共类型的时候,推断的结果是产生一个空对象,{}。因为这个类型不含任何成员,对于其任何属性的访问都会导致错误。这种结果依然允许我们在忽略类型的方式中使用对象,但在保障类型安全的前提下,该对象的类型不能被隐式的确定。

上下文(语境)类型

在TypeScript中,类型推断在某些情况下也存在于"其他方面"。这被称为"上下文归类"。上下文归类发生在当一个表达式的类型在其所在的上下文中被隐式的指定的时候。例如:

上面的代码将会给出一个类型错误,TypeScript的类型检查器使用Window.onmousedown函数的类型来推断右边的函数表达式类型。当它这么做的时候,便能够推断出参数mouseEvent的类型。 如果这个表达式不在可进行上下文归类的位置,参数mouseEvent 需要给定一个any类型,这样就不会出现错误了。

如果需要上下文归类的表达式内容中包含明确的类型信息,则会忽略上下文归类。我们重写上面的例子:

参数明确指定类型的函数表达式将会忽略上下文归类。经过这样的处理就不会报错了,因为没有应用到上下文归类。

上下文归类可应用于许多场景。常见的场景包括函数调用的参数、赋值的等号右边表达式、类型确定、对象成员和数组字面量、返回值语句。上下文类型也作为最佳公共类型的候选类型。例如:

在这个例子中,最佳公共类型有四个候选类型:Animal,Rhino,Elephant,和Snake。其中,Animal可以作为最佳公共类型。

形式有点像数学中的求最小公倍数...

关于Bootstrap弹出框无法调用问题的解决办法 问题描述写项目中使用到了前端框架bootstrap,提供的功能很强大!bootstrap学习然而在用bootstrap提供的弹出框组件时,弹出框怎么也弹不出!按理说应该

基于javascript制作微信聊天面板 本文实例分享了javascript制作微信聊天面板的相关代码,具体内容如下先上图吧点击头像更换说话对象,简单说下实现原理,html中创建一个ul用于存放所

javascript实现可键盘控制的抽奖系统 制作一个简易的抽奖系统!欢迎大家学习!JS原理:建立一个数组用来存储抽奖内容,例如iphone6等,当点击开始的时候,开启定时器,产生一个随机数,

标签: TypeScript Type Innference(类型判断)

本文链接地址:https://www.jiuchutong.com/biancheng/377477.html 转载请保留说明!

上一篇:JavaScript File分段上传(js分段上传)

下一篇:关于Bootstrap弹出框无法调用问题的解决办法(bootstrap弹出表单)

  • 房产税计入哪个科目 新会计准则
  • 物业管理服务增值税2022
  • 讲师讲课费标准2019
  • 税控发票抵税还是抵收
  • 固定资产变动包括哪些内容
  • 工伤医疗费用个人社保卡支付找谁报销
  • 机动车发票申请流程
  • 事业单位发生管理费用
  • 生产企业的安全员好干吗
  • 调拨入库的固定资产是否缴税?
  • 进口货物的增值税是进项税还是销项税
  • 理财产品 会计分录
  • 软件开发服务费可以计入无形资产吗
  • 代收代付的发票开给谁
  • 企业股权转让有什么好处
  • 个税返还手续费增值税申报填在哪里
  • 收到认证费用计入什么科目
  • 计提个人负担的社会保险费分录
  • 外贸企业出口收入确定
  • 收到政府拨款怎么做账
  • 微软发布新windows
  • 公司补缴印花税的后果
  • 长期待摊费用是当月摊销还是次月摊销
  • php load
  • 佣金手续费开什么发票
  • 摊余成本计量的金融资产若溢价购买小于
  • 设备拆修痕迹影响大吗
  • sql代码大全
  • 小程序新版本
  • yolo object detection
  • es6体验
  • yum命令安装软件
  • php 模拟post
  • phpcms建站教程
  • 购置固定资产支付的现金属于投资活动产生的现金流量吗
  • 子公司认定消费税需要披露信息
  • 所得税包含哪些项目
  • 租赁办公场所的法律规定
  • 什么是临时雇佣
  • SQL Server 中 RAISERROR 的用法详细介绍
  • mongodb导入
  • 购礼品送客户的文案
  • 个税申报数据有误
  • 房地产开发企业增值税怎么算
  • 进项税额不得抵扣的情况
  • mysql怎么使用表
  • 建筑租赁公司是什么意思
  • 私人账户可以打钱到公司账户吗
  • 计提印花税会计分录
  • 以银行承兑汇票支付购买原材料款
  • 发票免税怎么做账
  • 发票抬头是个人税号怎么填
  • ubuntul
  • Mysql使用教程
  • 如何系统还原xp
  • windows service 2008 r2
  • 创建一个windows
  • mac所有窗口最小化
  • win7系统运行在哪里
  • linux CentOS WEB服务器分区方案
  • win1020h2版本千万别更新
  • xp怎么改w7
  • windows7桌面右击
  • win7浏览器怎么升级到最新版
  • cocos2dx用什么ide
  • 屏幕适配android常用方法
  • bootstrap怎样为进度条添加动画
  • node.js入门
  • 粒子form
  • js正则表达式gi
  • js date对象构造方法
  • jquery modal 弹窗
  • shell 执行sh
  • js控制并发数
  • 如何在android studio中导入其他包
  • jquery 获取父元素的子元素
  • LeakCanary小记
  • 医保属于地税还是国税
  • 个人所得税自行纳税申报表(A表)怎么填写
  • 贵州税务开票系统登录
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设