TypeScript构建工具

TypeScript构建工具

构建工具是编程实用程序,它有助于将源代码转换和捆绑成单个文件进行自动化。构建工具实用程序用于构建程序的新版本。构建意味着将代码编译,链接和打包成可执行形式。

构建工具通常在命令行上运行,无论是在IDE中还是完全独立于IDE。

构建工具或构建自动化是编写脚本或自动化各种开发人员在日常活动中进行的各种任务的行为。这些是:

  • 下载依赖项。
  • 将源代码编译为二进制代码。
  • 打包二进制代码。
  • 运行测试。
  • 部署到生产系统。

使用构建工具

在小型项目中,软件开发人员手动调用构建过程,这对于大型项目来说不是一个好的实践。这是因为在大型项目中,很难跟踪需要以什么顺序构建,什么应该是构建过程中的依赖项。因此,我们使用自动化工具来使构建过程更一致。

可以与TypeScript集成的一些标准构建工具是:

  1. Browserify
  2. Duo
  3. Grunt
  4. Gulp
  5. Jspm
  6. Webpack

TypeScript构建工具

1. Browserify

使用Browserify插件Tsify来编译TypeScript文件。

安装

使用以下命令安装Tsify

$npm install Tsify

使用命令行界面

使用以下命令编译代码,将结果保存在名为bundle.js的文件中。

browserify main.ts -p [ tsify --noImplicitAny ] > bundle.js

使用API

var browserify = require("browserify");
var tsify = require("tsify");

browserify()
    .add("main.ts")
    .plugin("tsify", { noImplicitAny: true })
    .bundle()
    .pipe(process.stdout);

2. Duo

安装

使用以下命令安装Duo插件

$npm install duo-typescript

使用命令行界面

使用以下命令编译代码,将结果保存在名为entry.ts的文件中。

$duo --use duo-typescript entry.ts

使用API

var Duo = require("duo");
var fs = require("fs")
var path = require("path")
var typescript = require("duo-typescript");

var out = path.join(__dirname, "output.js")

Duo(__dirname)
    .entry("entry.ts")
    .use(typescript())
    .run(function (err, results) {
        if (err) throw err;
        // Write compiled result to output file
        fs.writeFileSync(out, results.code);
    });

3. Grunt

使用来自Grunt的grunt-ts插件编译TypeScript文件。

安装

使用以下命令安装grunt-ts

$npm install grunt-ts

现在,您需要在您的项目中包含名为gruntfile.js的Grunt配置文件

module.exports = function(grunt) {
    grunt.initConfig({
        ts: {
            default: {
                src: ["**/*.ts", "!node_modules/**/*.ts"]
            }
        }
    });
    grunt.loadNpmTasks("grunt-ts");
    grunt.registerTask("default", ["ts"]);
};

4. Gulp

使用gulp-typescript插件编译TypeScript文件。

安装

使用以下命令安装gulp-typescript

$npm install gulp-typescript

现在,您需要在您的项目中包含名为gulpfile.jsGulp配置文件。

var gulp = require("gulp");
var ts = require("gulp-typescript");

gulp.task("default", function () {
    var tsResult = gulp.src("src/*.ts")
        .pipe(ts({
              noImplicitAny: true,
              out: "output.js"
        }));
    return tsResult.js.pipe(gulp.dest("built/local"));
});

5. Jspm

使用jspm插件编译TypeScript文件。

安装

使用以下命令安装jspm

$npm install -g jspm@beta

注意:jspm中的TypeScript支持目前在0.16beta

6. Webpack

使用ts-loader插件编译TypeScript文件。

安装

使用以下命令安装webpack

$npm install ts-loader --save-dev

现在,您需要在您的项目中包含名为webpack.config.js的Webpack配置文件

module.exports = {
    entry: "./src/index.tsx",
    output: {
        filename: "bundle.js"
    },
    resolve: {
        // Add '.ts' and '.tsx' as a resolvable extension.
        extensions: ["", ".webpack.js", ".web.js", ".ts", ".tsx", ".js"]
    },
    module: {
        loaders: [
            // all files with a '.ts' or '.tsx' extension will be handled by 'ts-loader'
            { test: /\.tsx?$/, loader: "ts-loader" }
        ]
    }
}

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程