zoukankan      html  css  js  c++  java
  • 类型推论

    1.基本的类型推论

    let name = "lison";
    name = 123; // error 不能将类型“123”分配给类型“string”

    2.当我们定义一个数组或元组这种包含多个元素的值的时候,多个元素可以有不同的类型,这种时候 TypeScript 会将多个类型合并起来,组成一个联合类型

    let arr = [1, "a"];
    arr = ["b", 2, false]; // error 不能将类型“false”分配给类型“string | number”

    此时的 arr 的元素被推断为string | number,也就是元素可以是 string 类型也可以是 number 类型,除此两种类型外的类型是不可以的

    3. 上下文类型

    window.onmousedown = function(mouseEvent) {
      console.log(mouseEvent.a); // error 类型“MouseEvent”上不存在属性“a”
    };

    我们可以看到,表达式左侧是 window.onmousedown(鼠标按下时发生事件),因此 TypeScript 会推断赋值表达式右侧函数的参数是事件对象,因为左侧是 mousedown 事件,所以 TypeScript 推断 mouseEvent 的类型是 MouseEvent。在回调函数中使用 mouseEvent 的时候,你可以访问鼠标事件对象的所有属性和方法,当访问不存在属性的时候,就会报错。

  • 相关阅读:
    TCP/IP四层模型
    Java中equals和==的区别
    最全前端资源汇集
    (转)php面向对象学习笔记
    学习内容
    Gulp入门教程
    seajs的CMD模式的优势以及使用
    正则
    Grunt
    Javascript 异步加载详解
  • 原文地址:https://www.cnblogs.com/guangzhou11/p/11314422.html
Copyright © 2011-2022 走看看