摘要:学习之路学习之路安装环境起步开发工具自动编译文件中的数据类型中的函数中类的定义继承中的继承中的继承类的静态属性和静态方法类的多态的抽象类中的接口中的泛型学习之路安装环境查看版本起步新建通过命令编译此时路径下
npm install -g typescript
查看版本
tsc -v
1、新建hello.ts
const hello : string = "Hello World!"console.log(hello)
2、通过 tsc 命令编译
tsc hello.ts
3、此时路径下会生成一个hello.js文件
var hello = "Hello World!";console.log(hello);
4、node hello.js打开或者引入xxx.html浏览器打开查看
1、创建 tsconfig.json
文件 cmd后执行命令 tsc --init
生成配置文件
然后就可以自动编译.ts文件
// typescript中为了使编写代码更加规范 有利于维护 增加了类型校验 /* 布尔类型 boolean 数字类型 number 字符串类型 string 数组类型 array 元祖类型 tuple 枚举类型 enum 任意类型 any null 和undefined void类型 never类型*/// 布尔类型 booleanvar flag: boolean = trueflag = false// 数字类型 numbervar num: number = 123console.log(num);// 字符串类型 stringlet str: string = "fqniu"console.log(str);// 数组类型 array// 第一种定义let arr1: number[] = [1, 2, 3, 4]console.log(arr1);let arr2: string[] = ["1", "2", "3", "4"]console.log(arr2);// 第二种定义let arr3: Array<number> = [1, 2, 3, 4]let arr4: Array<string> = ["1", "2", "3", "4"]// 第三种定义let arr5: any[] = [1, 2, "3", 4, true]// 元祖类型 tuple (定义数组的一种方式)let arr7: [string, number, boolean] = ["fqniu", 25, true]// 枚举类型 enumenum Flag { success = 1, error = -1 }let fs: Flag = Flag.successlet fe: Flag = Flag.errorconsole.log(fs, fe); // 1 -1enum Color { red, blue, yellow } // 如果这里默认不赋值的话打印的是索引值 0 1 2let c: Color = Color.yellowconsole.log(c); // 2 enum Color1 { red, blue = 5, yellow } // 如果这里默认不赋值的话打印的是索引值 0 1 2let cr: Color1 = Color1.redlet cb: Color1 = Color1.bluelet cy: Color1 = Color1.yellowconsole.log(cr); // 0console.log(cb); // 5console.log(cy); // 6 取上一个值, blue的值 +1// 任意类型 any let numAny: any = 25numAny = "fqniu"numAny = trueconsole.log(numAny);// any的用处:获取dom元素节点 操作dom的样式等// var oBox: any = document.getElementById("box")// oBox.style.color = "red"// null 和undefinedlet undef: undefinedconsole.log(undef);var nul: nullnul = nullconsole.log(nul);// 一个元素可能是 number类型 可能是null 可能是undefinedvar ele: number | null | undefinedconsole.log(ele);// void类型 typescript 中的void表示没有任何类型 一般用于定义方法的时候 方法没有返回值function fun(): void { console.log("fun");}fun()// 有返回值时function fun1(): number { console.log("fun"); return 123}fun1()// never类型:其他类型(包括null 和undefined)的子类型,代表从不会出现的值,这意味着声明never的变量只能被never类型所赋值let error:never// error = 25 // 报错// 正确error = (() => { throw new Error("错误")})()
// 函数的定义// js中函数声明定义function fun1() { }// js中匿名函数定义 函数表达式var fun2 = function () { }// ts中函数声明定义function fun3(): string { return "fqniu"}console.log(fun3()); // fqniu// ts中匿名函数定义 函数表达式var fun4 = function (): number { return 25}console.log(fun4()); // 25// 1、函数的传参function fun5(name: string, age: number): string { return `${name} -- ${age}`}console.log(fun5("fqniu", 25)); // fqniu -- 25var fun6 = function (name: string, age: number): string { return `${name} -- ${age}`}console.log(fun6("nfq", 22)); // nfq -- 22// 没有返回值的方法function fun7(): void { console.log("fun7");}fun7()// 2、函数的可选参数// es5里面的方法的实参和形参可以不一样// 但是ts必须一致,不一样的话可以配置可选参数,注意参数必须配置到参数的最后一个 加?function fun8(name: string, age?: number): string { if (age) { return `${name} -- ${age}` } else { return `${name} -- 保密` }}console.log(fun8("fqniu")); // fqniu -- 保密console.log(fun8("fqniu", 25)); // fqniu -- 25// 3、默认参数// es5里面没办法设置默认参数,es6和ts可以设置默认参数function fun9(name: string, age = 20): string { if (age) { return `${name} -- ${age}` } else { return `${name} -- 保密` }}console.log(fun9("fqniu")); // fqniu -- 20console.log(fun9("fqniu", 25)); // fqniu -- 25// 4、剩余参数function sum1(a: number, b: number, c: number, d: number): number { return a + b + c + d}console.log(sum1(1, 2, 3, 4)); // 10function sum2(...result: number[]): number { var sum = 0 for (var i = 0; i < result.length; i++) { sum += result[i] } return sum}console.log(sum2(1, 2, 3, 4, 5, 6)); // 21// 5、函数的重载// Java中方法的重载,是指的两个或者多个同名函数,但是他们的参数不一样,这时会出现函数重载的情况// ts中的重载:通过为同一个函数提供多个函数类型定义来实现多种功能的目的function getInfo(name: string): string;function getInfo(age: number): string;function getInfo(str: any): any { if (typeof str === "string") { return "我叫 " + str } else { return "我的年龄是" + str }}console.log(getInfo("fqniu"));console.log(getInfo(22));// 6、箭头函数// this指向上下文setTimeout(() => { console.log("fqniu ws");}, 2000);
// ts中类的定义class Person { name: string; //属性 前面省略public关键词 constructor(name: string) { // 构造函数 实例化类的时候触发的方法 this.name = name; } fun(): void { console.log("fun", this.name); } getName(): string { return this.name } setName(name: string): void { this.name = name }}var p = new Person("fqniu")console.log(p.name); // fqniuconsole.log(p.getName()); //fqniup.setName("niuniu")console.log(p.getName()); // niuniu
function Person() { this.name = "fqniu" /*属性*/ this.age = 25 this.fun = function () { console.log(this.name + this.age); } } var p = new Person() console.log(p.name); p.fun() // 原型链上的属性会被多个实例共享,但是构造函数不会 Person.prototype.sex = "男" Person.prototype.work = function () { console.log(this.name + "敲代码"); } p.work() // 添加静态方法 Person.getInfo = function () { console.log("我是静态方法"); } Person.getInfo() // es中的继承 继承Person类 // 1、对象冒充实现继承 function Web1() { Person.call(this) //对象冒充实现继承 } var web1 = new Web1() web1.fun() // 对象冒充实现继承构造函数中的属性和方法 // web.work() // 报错 index.html:48 Uncaught TypeError: web.work is not a function 但是没办法继承原型链上的属性和方法 // 2、原型链实现继承 function Web2() { } Web2.prototype = new Person() // 原型链实现继承 var web2 = new Web2() console.log(web2.name); // fqniu web2.fun() // fqniu25 web2.work() // fqniu敲代码 // 原型链实现继承好处:既可以继承构造函数中的属性和方法,也可以继承原型链上的方法 // 原型链实现继承的问题? 当实例化子类的时候,没办法给父类传参 function Person1(name, age) { this.name = name /*属性*/ this.age = age this.fun = function () { console.log(this.name + this.age); } } function Web3(name, age) { } Web3.prototype = new Person1() // 原型链实现继承 var web3 = new Web3("nfq", 25) console.log(web3.name); // undefined 因为实例化子类的时候,没办法给父类传参 // 组合继承模式 function Person2(name, age) { this.name = name /*属性*/ this.age = age this.fun = function () { console.log(this.name + this.age); } } Person2.prototype.sex = "男" Person2.prototype.work = function () { console.log(this.name + "敲代码"); } function Web4(name, age) { Person2.call(this, name, age) // 对象冒充继承,实例化子类可以给父类传参 } Web4.prototype = new Person2() // 原型链实现继承 // 或者 // Web4.prototype = Person2.prototype var web4 = new Web4("nfq", 25) console.log(web4.name); // nfq web4.fun() // nfq25 web4.work() // nfq敲代码
// ts中实现继承 extends、 superclass Person { name: string; //属性 前面省略public关键词 constructor(name: string) { // 构造函数 实例化类的时候触发的方法 this.name = name; } fun(): void { console.log("fun", this.name); } getName(): string { return this.name } setName(name: string): void { this.name = name }}class Web extends Person { constructor(name: string) { super(name) // 初始化父类的构造函数 } work(): void { console.log(`${this.name}在敲代码`); } // fun(): void { // console.log("fun - 子类", this.name); // }}var w = new Web("fqniu")w.fun() // fun fqniuw.work() // fqniu在敲代码// 类里面的修饰符 typescript里面定义属性的时候提供了三种修饰符/* public:公有 —— 在当前类里面、子类、类外面都可以访问 protected:保护类型 —— 在当前类里面,子类都可以访问,在类外部无法访问 provite:私有 —— 只有当前类里面访问,子类、类外部都无法访问 属性不加修饰
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/124023.html
摘要:前端日报精选腾讯前端团队社区源码分析入门指南一些关于使用的心得基本类型与引用类型知多少掘金中文第期框架选型周刊第期入门系列模块车栈重构基于的网络请求库某熊的全栈之路的那些奇技淫巧的平凡之路模仿写个数组监听掘 2017-07-01 前端日报 精选 Why you shouldn`t use Preact, Fast-React, etc. to replace React today -...
摘要:前端日报精选专题之类型判断下百度生态构建发布基于的解决方案将全面支持从绑定,看语言发展和框架设计掘金译机器学习与一付费问答上线,向你心目中的大牛提问吧产品技术日志中文第期团队技术信息流建设翻译基于路由的异步组件加载个必备的装逼 2017-07-06 前端日报 精选 JavaScript专题之类型判断(下) · Issue #30 · mqyqingfeng/Blog 百度Web生态构...
摘要:目前稳定在,进入了版本状态,谷歌表示会长期进行支持。版本是谷歌开发的一款类型的框架,具有优越的性能和绝佳的跨平台性。于年月正式发布,目前已发布到版本。中文翻译与主站同步的非常及时。 Angular是一款面向企业级应用开发的前端框架,掌握好Angular相关技术,有助于我们提升开发效率,编写高质量的前端代码。 Angular 1.x版本 AngularJS 诞生于2009年,由Misko H...
本文收集学习过程中使用到的资源。 持续更新中…… 项目地址 https://github.com/abc-club/f... 目录 vue react react-native Weex typescript Taro nodejs 常用库 css js es6 移动端 微信公众号 小程序 webpack GraphQL 性能与监控 高质文章 趋势 动效 数据结构与算法 js core 代码规范...
阅读 1160·2023-04-26 02:38
阅读 1424·2021-11-22 09:34
阅读 1149·2021-09-26 10:19
阅读 3096·2019-08-29 17:15
阅读 3493·2019-08-29 12:27
阅读 1662·2019-08-26 13:51
阅读 1842·2019-08-26 13:47
阅读 992·2019-08-26 12:20