当前位置: 首页 > news >正文

建设工程类网站网站建设的组织机构

建设工程类网站,网站建设的组织机构,window主机用wordpress,内蒙古工程建设协会网站ts的常用类型前言安装ts常见类型原始类型 、数组、 any变量上的类型注解函数对象类型联合类型类型别名接口接口和类型别名的对比前言 typescript中为了使编写的代码更规范,更有利于维护,增加了类型校验,安装 安装 typescript npm i typescr…

ts的常用类型

  • 前言
  • 安装
  • ts常见类型
    • 原始类型 、数组、 any
    • 变量上的类型注解
    • 函数
    • 对象类型
    • 联合类型
    • 类型别名
    • 接口
      • 接口和类型别名的对比


前言

typescript中为了使编写的代码更规范,更有利于维护,增加了类型校验,

安装

安装 typescript
npm i typescript -g
运行
tsc hello.ts

ts常见类型

原始类型 、数组、 any

类型举例描述
string“Hello word”表示字符串
number42所有的数字,类型都是 number
booleantrue 和 false布尔值
Array①var arr:number[]=[11,22,33] ② var arr:Array=[11,22,33];数组
anylet obj: any = { x: 0 };当你不希望一个值导致类型检查错误的时候,就可以设置为 any

变量上的类型注解

当你使用 const、var 或 let 声明一个变量时,你可以选择性的添加一个类型注解,显式指定变量的类型

let myName: string = "Alice";

函数

参数类型注解(Parameter Type Annotations)

当你声明一个函数的时候,你可以在每个参数后面添加一个类型注解,声明函数可以接受什么类型的参数。参数类型注解跟在参数名字后面:

function greet(name: string) {console.log("Hello, " + name.toUpperCase() + "!!");//当参数有了类型注解的时候,TypeScript 便会检查函数的实参:
}

对象类型

function printCoord(pt: { x: number; y: number }) {console.log("The coordinate's x value is " + pt.x);console.log("The coordinate's y value is " + pt.y);
}
printCoord({ x: 3, y: 7 });

可选属性:对象类型可以指定一些甚至所有的属性为可选的,你只需要在属性名后添加一个 ? :

function printName(obj: { first: string; last?: string }) {console.log(obj.last.toUpperCase());//可能为undefined,所以要先判断下if (obj.last !== undefined) {// OKconsole.log(obj.last.toUpperCase());}
}
// Both OK
printName({ first: "Bob" });
printName({ first: "Alice", last: "Alisson" });

联合类型

基于已经存在的类型构建新的类型,现在把它们组合在一起。

function printId(id: number | string) {console.log("Your ID is: " + id);
}
// OK
printId(101);
// OK
printId("202");
// Error
printId({ myID: 22342 });
// Argument of type '{ myID: number; }' is not assignable to parameter of type 'string | number'.
// Type '{ myID: number; }' is not assignable to type 'number'.
// 因为定义的参数类型为数字或者字符串,对象不符合条件

注:必须对每个联合的成员都是有效的。举个例子,如果你有一个联合类型 string | number , 你不能使用只存在 string 上的方法:

function printId(id: number | string) {console.log(id.toUpperCase());// Property 'toUpperCase' does not exist on type 'string | number'.// Property 'toUpperCase' does not exist on type 'number'.//解决方法 用typeof 先判断一下类型,在执行方法
}

类型别名

顾名思义,一个可以指代任意类型的名字。

type Point = {x: number;y: number;
};// Exactly the same as the earlier example
function printCoord(pt: Point) {console.log("The coordinate's x value is " + pt.x);console.log("The coordinate's y value is " + pt.y);
}printCoord({ x: 100, y: 100 });

你可以使用类型别名给任意类型一个名字,举个例子,命名一个联合类型:

type ID = number | string;

接口

interface Point {x: number;y: number;
}function printCoord(pt: Point) {console.log("The coordinate's x value is " + pt.x);console.log("The coordinate's y value is " + pt.y);
}printCoord({ x: 100, y: 100 });

接口和类型别名的对比

  • 相同点: 都可以给对象指定类型
  • 不同点:
    • 接口:只能为对象指定类型
    • 类型别名:不仅可以为对象指定类型,实际上可以为唯衣类型指定别名
http://www.yayakq.cn/news/958516/

相关文章:

  • 网站建设哈尔滨网络科技有限公司网站
  • 专业做网站的公司有哪些宁波小程序开发
  • 深圳品牌网站制作平台网站类软文
  • 网站开发平台建设优化推广网站排名
  • 做旅游网约车的网站网站建设吉金手指专业11
  • 简单响应式网站设计代码wordpress 分享实现
  • 做进化树的网站wordpress 下拉菜单插件
  • 中企动力科技股份有限公司网站官网早教网站模板
  • 怎么注册微信小商店阿克苏网站建设优化
  • 建设方案在线seo超级外链工具
  • 网站虚拟空间百度站长平台清退
  • 昌吉网站建设设计素材网站p
  • 网站开发搜索功能创意网站交互
  • 南充做网站电话网站链接分析
  • 网站首页框架图建筑信息平台app
  • 有没有免费网站制作丹阳网站推广
  • 平面设计类网站有哪些国家建设信息公示平台
  • 用花生棒做网站快吗企业网页设计
  • 网站建设与制作设计公司南京 网站备案
  • 做网站前怎么建立数据结构番禺人才网地址
  • 手机网站建设必要性有了域名后怎么建设网站
  • 杭州大江东建设局网站给网站做图
  • 网站keyword如何排列自助业务商城
  • 网站建设登录注册怎么做泰安网站建设制作
  • 网站开发技术服务费seo优化专员
  • 园林建设网站江苏做网站怎么收费多少
  • 平面设计工作室网站免费php网站有哪些
  • 雄安专业网站建设哪家好临沂企业建站
  • 网站开发学什么语言最好建行输了三次密码卡锁怎么解
  • 当涂城乡建设局的网站wordpress采集教程