zoukankan      html  css  js  c++  java
  • [求教]利用typescript对Javascript做强类型检测提示

    近期在学习typescript的时候,发现ts居然可以对原生js做强检测。发现从v2.3就开始直接了。这让我感叹他的变化,又让我自己感到学习的缓慢。本文章就对他小试牛刀一下。

    一、他是的使用与支持

    通过阅读官网的说明,了解到他实现验证是通过jsdoc的注释结构实现。然后在.js文件头部加入如下注释标签即可:

    标记 说明
    // @ts-nocheck 标记此文件不做类型检测
    // @ts-check 标记此文件做类型检测,但没有用--checkJS参数时
    // @ts-ignore 标记后面一段不做类型检测(可以说是后面一行)

    二、示例展示

    简要示例代码如下:

    // @ts-check
    
    /**
     * @type {number}
     */
    var x;
    
    x="12";

    效果图如下:

    是否很神奇,编译环境能识别出类型的差异。其他测试截图如下:

    三、疑问

    1. 按照官网的说明,对object对象也可以做到检测,但测试貌似不可以,还望各位帮忙解疑(官网原话如下):

    Object literals are open-ended

    By default object literals in variable declarations provide the type of a declaration. No new members can be added that were not specified in the original initialization. This rule is relaxed in a .js file; object literals have an open-ended type, allowing adding and looking up properties that were not defined originally. For instance:

    var obj = { a: 1 };
    obj.b = 2;  // Allowed

    Object literals get a default index signature [x:string]: any that allows them to be treated as open maps instead of closed objects.

    Similar to other special JS checking behaviors, this behavior can be changed by specifying a JSDoc type for the variable. For example:

    /** @type  */
    var obj = { a: 1 };
    obj.b = 2;  // Error, type {a: number} does not have property b
  • 相关阅读:
    Ch04-文字列表的设计
    ch03-文字版面的设计
    ch02-HTML的基本概念
    【转】网站建设常用工具
    XSY1036 [Apio2012]派遣
    HDU1512 Monkey King
    快速构造FFT/NTT
    支配树学习笔记
    BZOJ1026[SCOI2009]windy数
    扩展欧几里得算法(exGCD)学习笔记
  • 原文地址:https://www.cnblogs.com/cqhaibin/p/8123999.html
Copyright © 2011-2022 走看看