码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • TypeScrip


    TypeScript强调了两个重要的特性--类型系统、适用于任何规模的项目

    1、TypeScript

    从名字就可以看出来,类型是其核心的特性。

    我们知道,JavaScript是一门非常灵活的编程语言,他有以下一些特点:

    • 没有类型约束,一个变量可以初始化是字符串,又可以转换为其他类型
    • 由于隐式类型转换的存在,有的变量的类型很难在运行前就确定
    • 基于原型的面向对象编程
    • 函数是JS中的一等公民,可以赋值给变量,也可以当做参数或返回值

    JS灵活性使得JS蓬勃发展,但是代码质量参差不齐,维护成本高,运行时错误多。

    TypeScript的类型系统,在很大程度上弥补了JS的缺点。

    TypeScript是静态类型、弱类型

    1.  静态类型是指编译阶段就能知道变量的类型,在编译阶段就会进行类型检查,所以在编译阶段就会报错。动态类型可能就是在运行的时候才会报错。
    2. 弱类型是指【允许隐式类型转换】,如下
    1. console.log(1 + '1');
    2. // 打印出字符串 '11'

    2、原始数据类型

            原始数据类型包括:布尔值、数值、字符串、null、undefined 以及ES6中的新类型Symbol和ES10中的新类型BigInt。

    1. //1、boolean类型
    2. let isDone: boolean = false;
    3. // es6 let isDone = false;
    4. //2、number类型
    5. let age:number = 18;
    6. // es6 let age = 18;
    7. //3、string类型
    8. let str:string = 'Hellen';
    9. // es6 let str = 'Hellen';
    10. //4、空值
    11. let unusable: void = undefined;
    12. //5、Null和Undefined
    13. let u: undefined = undefined;
    14. let n: null = null;

    2、任意值

    •  如果是普通类型,在赋值过程中改变类型是不被允许的。例如如下会报错
    1. let myFavoriteNumber: string = 'seven';
    2. myFavoriteNumber = 7;
    3. //error
    • 可以使用any类型,则允许被赋值为任意类型
    1. let myFavoriteNumber: any = 'seven';
    2. myFavoriteNumber = 7;
    • 未申明类型的变量,默认为any类型

    1. let something;
    2. something = 'seven';
    3. something = 7;

    3、联合类型

            使用|分隔类型,意思允许这些类型,但是不允许其他类型。

    1. let myFavoriteNumber: string | number;
    2. myFavoriteNumber = 'seven';
    3. myFavoriteNumber = 7;

    4、数组类型

    有三种定义方式:

    •  表示方法:类型[],不允许出现其他类型
    let fibonacci: number[] = [1, 1, 2, 3, 5];
    
    • 数组泛型
    let fibonacci: Array = [1, 1, 2, 3, 5];
    
    • 接口表示数组 
    1. interface NumberArray {
    2. [index: number]: number;
    3. }
    4. let fibonacci: NumberArray = [1, 1, 2, 3, 5];
    • 类数组

      arguments 实际上是一个类数组,不能用普通的数组的方式来描述,而应该用接口:

    1. interface IArguments {
    2. [index: number]: any;
    3. length: number;
    4. callee: Function;
    5. }
    6. function sum() {
    7. let args: IArguments = arguments;
    8. }
    • any在数组中的应用
    let list: any[] = ['npm8', 25, { website: 'https://npm8.com' }];
    

    5、函数类型

            JS有两种常见的定义函数的方式:函数声明和函数表达式

    1. // 函数声明(Function Declaration)
    2. function sum(x, y) {
    3. return x + y;
    4. }
    5. // 函数表达式(Function Expression)
    6. let mySum = function (x, y) {
    7. return x + y;
    8. };

            在JS中对他的类型进行约束:

    1. function sum(x: number, y: number): number {
    2. return x + y;
    3. }
    4. let mySum: (x: number, y: number) => number = function (x: number, y: number): number {
    5. return x + y;
    6. };

    6、类型推论

    let num = 123

             以上没有显式申明变量类型,但是鼠标放在num上,会发现TS自动把变量类型推断为number类型。

    7、类型断言

            当变量类型是确定的时候,可以使用断言,断言的方式有两种:

    • <>和as
    1. let some:any = 'Hellen';
    2. //<>
    3. let strLen:number = ( some).length
    4. //as
    5. let strLen:number = (some as string).length

            类型断言的常见用途就是:

    • 将一个联合类型断言为其中的一个类型。
    1. interface Cat {
    2. name: string;
    3. run(): void;
    4. }
    5. interface Fish {
    6. name: string;
    7. swim(): void;
    8. }
    9. function isFish(animal: Cat | Fish) {
    10. //1.error
    11. //if(typeof animal.swim == function)
    12. //2.解决
    13. if (typeof (animal as Fish).swim === 'function') {
    14. return true;
    15. }
    16. return false;
    17. }

    参考文章:

    1. 什么是TypeScript · TypeScript开发手册TypeScript入门教程|TypeScript开发手册|TypeScript介绍icon-default.png?t=N7T8https://ts.npm8.com/part/introduction/what-is-ts.html

    TypeScript 学废了 - 掘金项目开发中基本离不开 TypeScript 来规范 JS 的类型,这篇文章主要总结 TypeScript 的基本知识。(没有 TypeScript 的项目就像奶茶里没有奶,哈哈哈~icon-default.png?t=N7T8https://juejin.cn/post/7025256684947767332

  • 相关阅读:
    【Groovy】递归遍历文件,匹配/排除指定的文件
    python-数据分析-numpy、pandas、matplotlib的常用方法
    【竞技宝】DOTA2-梦幻联赛S22:AR命悬一线 XG确定晋级淘汰赛
    TDesign的input标签
    商城项目09_品牌管理菜单、快速显示开关、阿里云进行文件上传、结合Alibaba管理OSS、服务端签名后直传
    Thread 和 ThreadPool 简单梳理(C#)【并发编程系列_3】
    账号安全基本措施2
    【Spring】普通类获取Spring容器的bean的方法
    微软同“亲女儿”小冰单飞后的再联手,AI 数字员工可行吗?
    MySQL篇---第二篇
  • 原文地址:https://blog.csdn.net/qq_42794545/article/details/121992171
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号