热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何从JavaScript跨越到TypeScript[基础进阶知识点]

从入门到放弃的java初中时自学过JAVA,学了大概一个多月吧,学了一个多月,看视频这些,后面放弃了编程。依稀记得,那段日子极度苦逼,我想如果当时是学javaScript就好了。说
从入门到放弃的java
  • 初中时自学过JAVA,学了大概一个多月吧, 学了一个多月,看视频这些,后面放弃了编程。 依稀记得,那段日子极度苦逼,我想如果当时是学Javascript就好了。
  • 说正事,typeScript现在真的很火,听过一句话,大项目,好点的公司,必须上typeScript,还有React,没有为什么,这里并不是说其他的技术不好,只是说大型项目,最好TS,它对于我们后期代码维护,前期的调试能省去很多时间。
  • Node.js之快速搭建微信公众号服务器
  • Node.js之快速搭建服务器+前后端数据库session交互
  • ES6教程全篇
  • 前端中大厂面试必问 原生Javascript操作

想学习typeScript,我觉得你首先要对原生Javascript非常熟练,最基础的知识最重要,然后要掌握ES5+ES6+ES7(7以后的最好知道一些),新技术掌握了,以后就不会那么累。 typeScript =type+ Javascript ,在ES5/6/7+Javascript基础上加了一个type!

  • TS相对JS来说,它真的非常严格,只要稍微不匹配接口或者值的类型,又或者是参数的个数不对,值改变后跟原值类型不

一致,都会导致报错。 建议使用npm 全局安装typeScript 然后使用 tsc *.ts 进行编译TS文件

  • ‘typeScript的新增核心概念:’
  • let app:string=2;这段代码就会报错,因为值 2 是一个number,而规定app是string类型,这样在TS中会报错的

新增值的类型:

  • any:可以是任意类型
  • vold:一个空的返回类型,比如function move():vold{} 这样代表这个函数没有返回值 ,如果换成any,那么就随便这个

函数返回什么类型,但是他必须return 否则TS会报错

新增概念:类型推论

  • let app = ‘hello’ ; app=1 ; 这段代码就会报错,因为TS把他当成了 let app:string = ‘hello’,再次改变

app的值,必须是string类型,否则报错 ,这就是类型推论

联合类型

  • let app: string | number = ‘hello’ ; app = 1; 这段代码是不会报错的,因为app是一个联合类型的变量,它即可以是

string又可以是number,只要符合其中一个类型即可,当然你也可以写更多个。

接口 interface (前端程序员很难理解的点)

  • Javascript也是一门面向对象的语言,但是ES5中它是基于原型实现的,ES6中使用了class类,这样会更清晰的体会到

面向对象这一说法,但是实际在TS中的面向对象更加完整,它跟JAVA这些语言一样,通过接口和类去完整的面向对象编程。

  • 你可以把对象想象成一个女人 (在TS中抽象成一个变量 let app )
  • 我们使用接口去描述这个女人 (在TS中使用 let app : interfacename)
  • 最后使用一些方法去获得这个女人的联系方式 (在TS中使用class类里面的方法去实现)

比如 :

class ask{
name:string; tel ? :number ; //这里为什么加问号,因为你不一定能拿到她的号码,如果拿不到,那么便可以不传参数, 但是如果不加? ,你又没那么号码,那么你没有参数传进来,TS就会报错 age:number ; constructor(name,age,tel){
this.name=name;
this.age=age;
this.tel=tel
}
}
interface check {
name : string; age:number; tel ? :number; }
let woman :check = new ask ('rose',20,1888888888);//假设你拿到美女所有资料 传入构造函数

这样你可以打印一把 console.log(woman),看看它是怎样的,上面这段代码是没有报错的。

  • 上面的代码通过tsc命令编译成JS文件后

var ask = /* @class / (function () {

function ask(name, age, tel) {
this.name = name;
this.age = age;
this.tel = tel;
}
return ask;

}());

let woman = new ask(‘rose’, 20, 1888888888);

console.log(woman)


"这里要注意,很多TS的代码编译后,是不会出现在JS文件中,比如const enum的枚举, interface这些,当然后面还会遇到更多"
-------------
### 元组的概念

  • JS中的数组,能储存大量的内容,所谓的元祖,其实就是数据类型的不同的数组
  • [1,’1′,true,false] 其实这个就是一个元组,只是叫法不一样。

-------
### 枚举 enum 和 const enum的区别

  • enum app { red, blue, pink, deeppink }
  • console.log(app.red, app.blue, app.pink, app.deeppink) // 输出0,1,2,3
  • enum app2 { red = 2, blue, pink, deeppink }
  • console.log(app2.red, app2.blue, app2.pink, app2.deeppink) // 输出2,3,4,5
  • 枚举默认的第一个值是0;也可以自己定义,如果自定义和系统默认的冲突,TS是不认识的,

他也不会报错,但是我不建议你这样做,毕竟谁没事找事呢?

### 还有一种常量枚举

const enum Directions {

Up,
Down,
Left,
Right

}

let directiOns= [Directions.Up, Directions.Down, Directions.Left, Directions.Right];
// 结果是 0 1 2 3


* 假如包含了计算成员,则会在编译阶段报错:
* const enum Color {Red, Green, Blue = "blue".length};
* 常数枚举与普通枚举的区别是,它会在编译阶段被删除,并且不能包含计算成员。 一试便知

类和接口 (最重要的之一)

* 一个类一次只可以继承一个接口,但是可以一次对应多个接口
* 要想实现多个类继承,那么使用子类继续继承其他类,循环下去

interface check {

name: string;
age: number;
hobby: Array
fuck: number[] //这两种写法是一样的

}

class exp implements check {

name: string
age: number
hobby:Array
fuck: number[]
constructor(name, age, hobby, fuck) {
this.name = name;
this.age = age;
this.hobby = hobby;
this.fuck = fuck;
}

}

let app = new exp(‘hello’, 18, [1, 2, 3], [2, 3, 4])

-------经过TS编译后得到

var exp = /* @class / (function () {

function exp(name, age, hobby, fuck) {
this.name = name;
this.age = age;
this.hobby = hobby;
this.fuck = fuck;
}
return exp;

}());
var app = new exp(‘hello’, 18, [1, 2, 3], [2, 3, 4]);


typeScript可能最难的就是如何理解优雅的面向对象编程,接口interface只是为了描述而已,
真正去实现,需要class类去实现,ES6在typeScript中位置举足轻重,
所以我建议你先去学习原生Javascript+ES6再来学习typeScript,那样会轻松很多,
下面放一个阮一峰的ES6的学习文档链接,里面写得非常详细,一定要认真看。
[ECMAScript 6 入门](http://es6.ruanyifeng.com/)

推荐阅读
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • Android Studio Bumblebee | 2021.1.1(大黄蜂版本使用介绍)
    本文介绍了Android Studio Bumblebee | 2021.1.1(大黄蜂版本)的使用方法和相关知识,包括Gradle的介绍、设备管理器的配置、无线调试、新版本问题等内容。同时还提供了更新版本的下载地址和启动页面截图。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
author-avatar
yf_992258
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有