TypeScript + Webpack 环境搭建
TypeScript + Webpack 环境搭建步骤
- 安装Node.js
- 安装npm
- 创建一个npm项目
- 安装typescript,配置ts
- 安装webpack,配置webpack
初始化一个npm项目
npm init
将在项目根目录下创建package.json文件。文件目录结构如下
ts3-demo
|- src
  |- index.ts
|- package.json
全局安装typescript命令:
npm install -g typescript
可以使用以下命令来查看你的机器中是否安装了Node.js\ npm \ typescript,以及安装的版本。
node -v
npm -v
tsc -v
typescript compiler
typescript的编译器叫做 tsc。
假设有个src/index.ts 文件,将它编译成index.js,可以使用命令:
tsc src/index.ts --target es5
或者
tsc src/index.ts --target es3
启动观察模式,当ts文件更改之后,自动进行编译。
tsc src/index.ts --watch --target es5
// index.ts
export default class Index {
    title = 'Hello';
    name = 'Lori';
}
编译后结果
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var Index = /** @class */ (function () {
    function Index() {
        this.title = 'Hello';
        this.name = 'Lori';
    }
    return Index;
}());
exports.default = Index;
通常不会在terminal中敲命令来编译,而是在项目的根路径下,建一个json配置文件 tsconfig.json,来配置这些编译选项。
初始化tsconfig.json的命令:
tsc --init
然后在terminal中使用tsc命令,会发现项目中所有ts文件都被编译成了js文件。
tsc
配置tsconfig.json
{
  "compileOnSave": false,
  "compilerOptions": {
    "outDir": "./dist/out-tsc",
    "sourceMap": true,
    "declaration": false,
    "moduleResolution": "node",
    "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "target": "es5",
    "typeRoots": [
      "node_modules/@types"
    ],
    "lib": [
      "es2017",
      "dom"
    ]
  }
}
安装Webpack
npm install webpack webpack-cli --save-dev
安装ts-loader
npm install ts-loader --save-dev
安装Webpack插件 html-webpack-plugin
用于自动生成index.html文件。
npm install html-webpack-plugin --save-dev
配置webpack.config.ts
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
module.exports = {
    mode: "development",
    devtool: "inline-source-map",
    entry: "./src/index.ts",
    output: {
        path: __dirname + '/dist',
        filename: '[name].bundle.js'
    },
    resolve: {
        extensions: ['.ts', '.tsx', '.js']
    },
    plugins: [
        new HtmlWebpackPlugin({
            title: 'index'
        })
    ],
    module: {
        rules: [
            {
                test: /\.tsx?$/,
                use: 'ts-loader',
                exclude: /node_modules/
            }
        ]
    },
    devServer: {
        contentBase: path.join(__dirname, 'dist'),
        compress: true,
        historyApiFallback: true,
        hot: true,
    }
}
想要在debug时生成相应的map文件,注意两点:
tsconfig.json中 sourceMap 设置为 true
webpack.config.ts中 devtool: "inline-source-map"
配置package.json 添加命令
"scripts": {
    "start": "./node_modules/.bin/webpack-dev-server",
    "build": "./node_modules/.bin/webpack",
    "test": "echo \"Error: no test specified\" && exit 1"
  },
运行npm run build 进行编译。
文件目录结构如下
ts3-demo
|-dist
  |- index.html
  |- main.bundle.js
|- src
  |- index.ts
|- package.json
|- tsconfig.json
|- webpack.config.js
运行npm start 启动本地服务器。
TypeScript + Webpack 环境搭建的更多相关文章
- 第二章 TypeScript 开发环境搭建
		Mac OS X 下 TypeScript 开发环境搭建 一.集成开发环境 WebStrom VSCode 二.安装 TypeScript Homebrew(macOS 缺失的软件包管理器) ruby ... 
- webpack 环境搭建
		Webpack环境搭建 一.安装node 1.node官网下载node并安装----node里面内置了npm所以用在安装npm了 2.命令行输入node -v查看node是否安装成功 二.全局安装we ... 
- webpack环境搭建
		环境搭建参考:Webpack+vue+element逐步搭建开发环境 webpack入门:http://www.jianshu.com/p/42e11515c10f ----------------- ... 
- TypeScript开发环境搭建(Visual studio code)
		使用Visual Studio Code搭建TypeScript开发环境 1.TypeScript是干什么的 ? TypeScript是由微软Anders Hejlsberg(安德斯·海尔斯伯格,也是 ... 
- reac-native + typescript 的环境搭建
		一. RN-TS环境搭建 . 安装RN脚手架 yarn add create-react-native-app -g yarn global add typescript . 创建项目文件夹 crea ... 
- webpack环境搭建开发环境,JavaScript面向对象的详解,UML类图的使用
		PS:因为所有的设计模式都是基于面向对象来完成的,所以在讲解设计模式之前先来过一下面向对象都有哪些知识点 搭建开发环境 初始化npm环境 下载安装nodejs安装即可,nodejs自带npm管理包,然 ... 
- react+es6+webpack环境搭建以及项目入门
		前言:拖了这么久,小菜鸟终于开始正式应用react,和es6来开发项目了.之前超喜欢同学的一个博客风格,这里贴一下地址:https://iwenku.net/,PC端是他很久之前做的,最近他重新做了一 ... 
- angular2 基于webpack环境搭建
		目录结构: angular-quickstart |_ ts |_ app.ts |_ index.ts |_ index.html |_ package.json |_ tsconfig.json ... 
- node+webpack环境搭建 vue.js 2.0 基础学习笔记
		npm install -g vue //全局安装vue npm install -g webpack //全局安装webpack npm install -g vue-cli //全局安装vue-c ... 
随机推荐
- LockSupport详解
			concurrent包是基于AQS (AbstractQueuedSynchronizer)框架的,AQS框架借助于两个类: Unsafe(提供CAS操作) LockSupport(提供park/un ... 
- 2--面试总结-深入理解js线程进阶-宏任务微任务
			前言:Event Loop即时间循环,是指浏览器或Node的一种解决javascript单线程运行时不会阻塞的一种机制,也就是我们经常使用异步的原理 Js运行机制 1.不同运行环境,js运行 ... 
- solaris硬盘格式化分区
			创建EFI分区及挂载文件系统的过程: # format AVAILABLE DISK SELECTIONS: 0. c1t0d0 <LSI-MR9261-8i-2.12-557.86GB> ... 
- iOS  Core  Image-----十行代码实现微信朋友圈模糊效果
			昨天下午微信的朋友圈着实火了一把,在这之后好多程序员都通过抓包工具看到了原图,但是我却在想,网上说是在移动前端做到的那是怎么做到的呢,经过一些学习,终于掌握了一些Core Image的知识,做出了相应 ... 
- C#项目类型分三种,Dos(控制台),c/s(客户端与服务器),b/s(浏览器/服务器)
- qs的两个用途
			qs是npm安装的库 1.qs.stringify() 将对象序列化成URL的形式,以&进行拼接 const Qs = require('qs'); let obj= { method: ... 
- php XDebug配置和使用
			已本机php 5.5nts为例,php.ini配置如下: [XDebug] xdebug.profiler_append = 0 xdebug.profiler_enable = 1 xdebug.p ... 
- HDU 6438 Buy and Resell
			高卖低买,可以交易多次 维护一个优先队列,贪心 相当于每天卖出 用当前元素减优先队列最小得到收益 用0/卖出,1/买入标志是否真实进行了交易,记录次数 #include<bits/stdc++. ... 
- Beauty Values
			Beauty Values 题意:给$n$个数, 定义它的Beauty Values为所有连续子区间的(区间长度*区间内不同数字的数目)求和 求Beauty Values A[i]数组表示数字i最近一 ... 
- Hyperledger交易流程
			Hyperledger Fabric Network中的角色 在Hyperledger中,由三种类型的角色: Client:应用客户端,用于将终端用户的交易请求发送到区块链网络: Peers:负责维护 ... 
