美文网首页
开始使用typescript

开始使用typescript

作者: 泛酸的桂花酒 | 来源:发表于2020-07-03 15:04 被阅读0次

    环境所需

    • node --- 最新的稳定版
    • npm或者yarn
    • ide(各种个样看自己喜好)

    安装typescript

    有两种主要的方式来获取typescript工具:

    • 通过npm,yarn来安装
    • 通过ide安装,webstorm ,visual studio来安装
      npm安装命令如下:
    npm install -g typescript
    

    创建环境

    1.新建一个目录用并打开

    新建文件夹

    2.执行npm init将目录初始化:

    npm init
    

    3.同时初始化typescript:

    tsc --init
    

    初始化完毕应该如下图所示:


    初始化后文件目录

    接着配置一下ts配置文件

    {
      "compilerOptions": {
        "target": "es5",                            // 指定 ECMAScript 目标版本: 'ES5'
        "module": "commonjs",                       // 指定使用模块: 'commonjs', 'amd', 'system', 'umd' or 'es2015'
        "moduleResolution": "node",                 // 选择模块解析策略
        "experimentalDecorators": true,             // 启用实验性的ES装饰器
        "allowSyntheticDefaultImports": true,       // 允许从没有设置默认导出的模块中默认导入。
        "sourceMap": true,                          // 把 ts 文件编译成 js 文件的时候,同时生成对应的 map 文件
        "strict": true,                             // 启用所有严格类型检查选项
        "noImplicitAny": true,                      // 在表达式和声明上有隐含的 any类型时报错
        "alwaysStrict": true,                       // 以严格模式检查模块,并在每个文件里加入 'use strict'
        "declaration": true,                        // 生成相应的.d.ts文件
        "removeComments": true,                     // 删除编译后的所有的注释
        "noImplicitReturns": true,                  // 不是函数的所有返回路径都有返回值时报错
        "importHelpers": true,                      // 从 tslib 导入辅助工具函数
        "lib": ["es6", "dom"],                      // 指定要包含在编译中的库文件
        "typeRoots": ["node_modules/@types"],
        "outDir": "./dist",
        "rootDir": "./src"
      },
      "include": [                                  // 需要编译的ts文件一个*表示文件匹配**表示忽略文件的深度问题
        "./src/**/*.ts"
      ],
      "exclude": [
        "node_modules",
        "dist",
        "**/*.test.ts",
      ]
    }
    {
      "compilerOptions": {
        "target": "es5",                            // 指定 ECMAScript 目标版本: 'ES5'
        "module": "commonjs",                       // 指定使用模块: 'commonjs', 'amd', 'system', 'umd' or 'es2015'
        "moduleResolution": "node",                 // 选择模块解析策略
        "experimentalDecorators": true,             // 启用实验性的ES装饰器
        "allowSyntheticDefaultImports": true,       // 允许从没有设置默认导出的模块中默认导入。
        "sourceMap": true,                          // 把 ts 文件编译成 js 文件的时候,同时生成对应的 map 文件
        "strict": true,                             // 启用所有严格类型检查选项
        "noImplicitAny": true,                      // 在表达式和声明上有隐含的 any类型时报错
        "alwaysStrict": true,                       // 以严格模式检查模块,并在每个文件里加入 'use strict'
        "declaration": true,                        // 生成相应的.d.ts文件
        "removeComments": true,                     // 删除编译后的所有的注释
        "noImplicitReturns": true,                  // 不是函数的所有返回路径都有返回值时报错
        "importHelpers": true,                      // 从 tslib 导入辅助工具函数
        "lib": ["es6", "dom"],                      // 指定要包含在编译中的库文件
        "typeRoots": ["node_modules/@types"],
        "outDir": "./dist",
        "rootDir": "./src"
      },
      "include": [                                  // 需要编译的ts文件一个*表示文件匹配**表示忽略文件的深度问题
        "./src/**/*.ts"
      ],
      "exclude": [
        "node_modules",
        "dist",
        "**/*.test.ts",
      ]
    }
    {
      "compilerOptions": {
        "target": "es5",                            // 指定 ECMAScript 目标版本: 'ES5'
        "module": "commonjs",                       // 指定使用模块: 'commonjs', 'amd', 'system', 'umd' or 'es2015'
        "moduleResolution": "node",                 // 选择模块解析策略
        "experimentalDecorators": true,             // 启用实验性的ES装饰器
        "allowSyntheticDefaultImports": true,       // 允许从没有设置默认导出的模块中默认导入。
        "sourceMap": true,                          // 把 ts 文件编译成 js 文件的时候,同时生成对应的 map 文件
        "strict": true,                             // 启用所有严格类型检查选项
        "noImplicitAny": true,                      // 在表达式和声明上有隐含的 any类型时报错
        "alwaysStrict": true,                       // 以严格模式检查模块,并在每个文件里加入 'use strict'
        "declaration": true,                        // 生成相应的.d.ts文件
        "removeComments": true,                     // 删除编译后的所有的注释
        "noImplicitReturns": true,                  // 不是函数的所有返回路径都有返回值时报错
        "importHelpers": true,                      // 从 tslib 导入辅助工具函数
        "lib": ["es6", "dom"],                      // 指定要包含在编译中的库文件
        "typeRoots": ["node_modules/@types"],
        "outDir": "./dist",
        "rootDir": "./src"
      },
      "include": [                                  // 需要编译的ts文件一个*表示文件匹配**表示忽略文件的深度问题
        "./src/**/*.ts"
      ],
      "exclude": [
        "node_modules",
        "dist",
        "**/*.test.ts",
      ]
    }
    

    创建src目录

    mkdir src && touch src/index.ts
    
    image.png

    运行一个官网例子

    class Student {
        fullName: string;
        constructor(public firstName, public middleInitial, public lastName) {
            this.fullName = firstName + " " + middleInitial + " " + lastName;
        }
    }
    
    interface Person {
        firstName: string;
        lastName: string;
    }
    
    function greeter(person : Person) {
        return "Hello, " + person.firstName + " " + person.lastName;
    }
    
    let user = new Student("Jane", "M.", "User");
    
    document.body.innerHTML = greeter(user);
    

    输入命令编译

    tsc index.ts
    

    可以看到ts转化的js


    image.png

    加入html代码看看效果

    <!DOCTYPE html>
    <html>
        <head><title>test typescript</title></head>
        <body>
            <script
            src="index.js"
            >
            </script>
        </body>
    </html>
    

    打开在浏览器可以看到效果


    打印名字

    相关文章

      网友评论

          本文标题:开始使用typescript

          本文链接:https://www.haomeiwen.com/subject/ycajqktx.html