04 # 第一个 TypeScript 程序

初始化项目以及安装依赖

新建 ts_in_action 文件夾

bash 复制代码
npm init -y

安装好 typescript,就可以执行下面命令查看帮助信息

bash 复制代码
npm i typescript -g
tsc -h

创建配置文件,执行下面命令就会生成一个 tsconfig.json 文件

bash 复制代码
tsc --init

使用 tsc 编译一个 js 文件

新建 src/index.ts

ts 复制代码
let kaimo:string = "hello typescript"

执行下面命令编译该 ts 文件

bash 复制代码
tsc ./src/index.ts

编译结果如下:

js 复制代码
var kaimo = "hello typescript";

也可以使用 https://www.typescriptlang.org/play 查看

配置构建工具 webpack 环境

安装依赖

bash 复制代码
npm i [email protected] [email protected] [email protected] -D
npm i [email protected] [email protected] -D
npm i [email protected] [email protected] [email protected] -D

配置相应的环境

基础配置:

js 复制代码
// 公共环境配置

// 下面这行用于 vscode 中智能化自动提示 webpack 配置项
/** @type {import('webpack').Configuration} */

const HtmlWebpackPlugin = require("html-webpack-plugin");

const config = {
    entry: "./src/index.ts",
    output: {
        filename: "app.js"
    },
    resolve: {
        extensions: [".js", ".ts", ".tsx"]
    },
    module: {
        rules: [
            {
                test: /\.tsx?$/i,
                use: [
                    {
                        loader: "ts-loader"
                    }
                ],
                exclude: /node_modules/
            }
        ]
    },
    plugins: [
        new HtmlWebpackPlugin({
            template: "./src/tpl/index.html"
        })
    ]
};
module.exports = config;

开发配置:

js 复制代码
// 开发环境配置

// 下面这行用于 vscode 中智能化自动提示 webpack 配置项
/** @type {import('webpack').Configuration} */

const config = {
    devtool: "cheap-module-eval-source-map"
};

module.exports = config;

生产配置:

js 复制代码
// 生产环境配置

// 下面这行用于 vscode 中智能化自动提示 webpack 配置项
/** @type {import('webpack').Configuration} */

const CleanWebpackPlugin = require("clean-webpack-plugin");

const config = {
    plugins: [new CleanWebpackPlugin()]
};

module.exports = config;

webpack 文件入口配置:

js 复制代码
// webpack 文件入口

// 下面这行用于 vscode 中智能化自动提示 webpack 配置项
/** @type {import('webpack').Configuration} */

const merge = require("webpack-merge");
const baseConfig = require("./webpack.base.config");
const devConfig = require("./webpack.dev.config");
const proConfig = require("./webpack.pro.config");

const config = merge(baseConfig, process.NODE_ENV === "development" ? devConfig : proConfig);

module.exports = config;

package.json 脚本配置

json 复制代码
"scripts": {
    "start": "webpack-dev-server --mode=development --config ./build/webpack.config.js",
    "build": "webpack --mode=production --config ./build/webpack.config.js"
},

启动服务并且打包测试

添加模板

html 复制代码
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>TypeScript in Action</title>
    </head>
    <body>
        <div class="app"></div>
    </body>
</html>

添加功能

ts 复制代码
let kaimo:string = "hello typescript";

document.querySelectorAll(".app")[0].innerHTML = kaimo;

启动服务 npm run start,访问 http://localhost:8080/


打包 npm run build

相关推荐
巴巴博一16 分钟前
前端安全之DOMPurify基础使用
前端·vue.js·安全·typescript·html5
lee5762 小时前
用 Vue 3.5 TypeScript 重新开发3年前甘特图的核心组件
vue.js·typescript·甘特图
蒜香拿铁2 小时前
【typescript进阶篇】(第二章) 模块与命名空间
typescript
FE_C_P小麦2 小时前
使用 Redux Toolkit封装一个模块化的 store
react.js·typescript·redux
随笔记2 小时前
用create-react-app脚手架创建react项目报错怎么办
前端·react.js·typescript
程序员黄同学3 小时前
解释 TypeScript 中的枚举(enum),如何使用枚举定义一组常量?
javascript·ubuntu·typescript
行深6 小时前
历时百日,我用TypeScript重构了5W Star的JavaScript开源项目
前端·typescript
冬冬小圆帽21 小时前
防止手机验证码被刷:React + TypeScript 与 Node.js + Express 的全面防御策略
前端·后端·react.js·typescript
小p1 天前
初探typescript装饰器在一些场景中的应用
前端·typescript·nestjs
晓得迷路了1 天前
栗子前端技术周刊第 72 期 - 快 10 倍的 TypeScript、React Router 7.3、Astro 5.5...
前端·javascript·typescript