当前位置: 首页 > news >正文

TypeScript 构建工具之 webpack

在实际开发中,直接使用TypeScript 编译器的情况不多。
在项目中,需要使用构建工具对代码进行打包,不可能脱离项目使用TypeScript 编译器单独打包TypeScript 。

那如何将 webpack 和 TypeScript 进行集成?

参考文档:
webpack中文文档
Webpack TypeScript

在根目录下创建package.json文件:

npm init -y

安装核心依赖

  1. 首先确保已经安装了 Node.js 和 npm(或 yarn)。
  2. 在项目目录中,安装 Webpack 和相关的加载器及插件:
    • webpack:Webpack 的核心包。负责实际的模块打包和资源处理工作。
    • webpack-cli:是 Webpack 的命令行工具,提供命令好界面。
    • ts-loader:用于在 Webpack 中处理 TypeScript 文件。
    • typescript:TypeScript 编译器。

使用 npm 安装这些包的命令如下:

npm install -D webpack webpack-cli typescript ts-loader

配置 Webpack

在项目根目录下创建一个webpack.config.js文件,用于配置 Webpack。

基本配置示例:

// 引入 Node.js 的内置模块 path
const path = require('path');// module.exports用于导出 Webpack 的配置对象。
// webpack中的所有配置信息都写在 module.exports 里。
// 这个配置对象包含了诸如入口文件、输出设置、加载器规则、插件等信息,用于告诉 Webpack 如何构建项目。
module.exports = {// 指定入口文件entry: './src/index.ts',// 指定打包文件所在目录output: {// 指定打包文件的目录path: path.resolve(__dirname, 'dist'),// 打包后的文件filename: 'bundle.js'},// 指定 webpack 打包时要使用的模块module: {// 指定要加载的规则rules: [{// 指定规则生效的文件test: /\.ts$/, // 表示匹配所有的后缀名为ts的文件// 要使用的loaderuse: 'ts-loader',// 要排除的文件夹(只要路径里有node_modules,就不编译)exclude: /node_modules/,}]},resolve: {extensions: ['.tsx', '.ts', '.js'],},
}

在这个配置中:

  • const path = require('path');用于引入 Node.js 的内置模块 path
  • module.exports用于导出 Webpack 的配置对象。这个配置对象包含了诸如入口文件、输出设置、加载器规则、插件等信息,用于告诉 Webpack 如何构建项目。
    • entry指定了项目的入口文件。
    • output定义了输出的文件名和目录。
    • module.rules配置了对 .ts 文件的处理规则,使用 ts-loader进行编译,并排除了 node_modules目录下的文件。
    • resolve.extensions使得在导入模块时可以省略文件扩展名。

配置 TypeScript

在项目根目录下创建一个tsconfig.json文件,这是 TypeScript 的配置文件。
可以直接创建文件,使用命令行工具自动生成:

tsc --init

配置示例:

{"compilerOptions": {"module": "ES2015","target": "ES2015","strict": true}
}

编写 TypeScript 代码

在项目的src目录下创建 TypeScript 文件,例如index.ts,并编写你的 TypeScript 代码。

运行 Webpack 构建

  1. 直接使用npx执行命令:
npx webpack
  1. package.json文件配置一个执行命令后通过npm执行

package.json文件增加一个配置:

"scripts": {"build": "webpack"
},

配置后,就可以运行以下命令来启动 Webpack 构建:

npm run build

执行命令后,生成dist文件夹,打包成功。

webpack集成typescript后,如何在html中运行?

当使用 Webpack 集成 TypeScript 后,可以通过以下步骤在 HTML 中运行打包后的代码:

安装必要的插件

html-webpack-plugin:这是一个非常常用的 Webpack 插件,用于自动生成 HTML 文件,并将打包后的 JavaScript 文件注入到其中。
使用 npm 安装这个插件:

npm install html-webpack-plugin --save-dev

配置 Webpack

webpack.config.js文件中引入并配置html-webpack-plugin

// 引入 Node.js 的内置模块 path
const path = require('path');
// 引入html插件
const HtmlWebpackPlugin = require('html-webpack-plugin');module.exports = {// 配置webpack插件plugins: [new HtmlWebpackPlugin({template: './src/index.html', // 指定模板 HTML 文件的路径}),],
};

在这个配置中,创建一个HtmlWebpackPlugin的实例,并指定了一个模板 HTML 文件的路径。这个插件会根据模板文件生成一个新的 HTML 文件,并将打包后的 JavaScript 文件自动注入到其中。

创建 HTML 模板文件

在项目的src目录下创建一个index.html文件,作为模板文件。这个文件包含基本的 HTML 结构。

<!DOCTYPE html>
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>网页模板</title>
</head>
<body></body>
</html>

打包后的 JavaScript 文件会自动注入到<script>标签中。

运行 Webpack 构建

运行以下命令来启动 Webpack 构建:

npm run build

Webpack 会根据配置进行构建,并在dist目录下生成一个新的 HTML 文件,其中包含了打包后的 JavaScript 文件的引用。

在浏览器中运行

打开生成的 HTML 文件(位于dist目录下),浏览器就会加载并执行打包后的 TypeScript 代码。

如何实现项目有变更时,自动重新构建项目,并自动刷新浏览器?

安装必要的插件

webpack-dev-server:用于启动一个开发服务器,支持热模块替换(HMR)等功能。
使用 npm 安装这个插件:

npm install webpack-dev-server --save-dev

相当于在项目里安装了一个内置的Webpack 开发服务器,可以让项目直接在服务器中运行。这个服务器是与Webapck关联的,当项目有变更时,可以自动构建并更新浏览器页面。

配置 Webpack

运行 Webpack

运行以下命令来启动开发服务器:

npx webpack serve

配置后,使用package.json 配置 npm run serve ,执行命令就报错了,emmm,这一步就等我研究研究再来补上吧=-= 哪位大佬走过路过不要错过,求指点啊啊啊啊啊

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Spring框架中ReflectionUtils类
  • 2024.8.18
  • 作业帮 TiDB 7.5.x 使用经验
  • 梧桐数据库(WuTongDB):聊聊抽象语法树(Abstract Syntax Tree, AST)技术
  • P4727 [HNOI2009] 图的同构计数
  • OpenLayers 使用高德地图并绘制一些线,并用Android原生触发
  • ZK Rollup 的Sequencer
  • STM32通过I2C硬件读写MPU6050
  • Microsoft GraphRAG 执行流程
  • 【计算机硬件硬盘与储存设备】
  • 推荐一款开源特效制作软件(适用于Godot)
  • tcpdump入门——每种flag分别表示什么意思
  • ECMAScript6语法:默认参数和rest参数
  • 模型训练坎坷路--逐步提升模型准确率从40%到90%+
  • redis命令学习
  • [译]CSS 居中(Center)方法大合集
  • 「前端」从UglifyJSPlugin强制开启css压缩探究webpack插件运行机制
  • 30天自制操作系统-2
  • chrome扩展demo1-小时钟
  • Docker下部署自己的LNMP工作环境
  • GDB 调试 Mysql 实战(三)优先队列排序算法中的行记录长度统计是怎么来的(上)...
  • Java|序列化异常StreamCorruptedException的解决方法
  • JavaScript 奇技淫巧
  • JavaScript标准库系列——Math对象和Date对象(二)
  • java中的hashCode
  • python_bomb----数据类型总结
  • rc-form之最单纯情况
  • vue-cli在webpack的配置文件探究
  • Webpack4 学习笔记 - 01:webpack的安装和简单配置
  • -- 查询加强-- 使用如何where子句进行筛选,% _ like的使用
  • 构建二叉树进行数值数组的去重及优化
  • 今年的LC3大会没了?
  • 前端 CSS : 5# 纯 CSS 实现24小时超市
  • 区块链将重新定义世界
  • 实战|智能家居行业移动应用性能分析
  • 新手搭建网站的主要流程
  • 一道面试题引发的“血案”
  • 运行时添加log4j2的appender
  • 在Unity中实现一个简单的消息管理器
  • 责任链模式的两种实现
  • python最赚钱的4个方向,你最心动的是哪个?
  • 通过调用文摘列表API获取文摘
  • 正则表达式-基础知识Review
  • 资深实践篇 | 基于Kubernetes 1.61的Kubernetes Scheduler 调度详解 ...
  • ​​​【收录 Hello 算法】9.4 小结
  • ​人工智能之父图灵诞辰纪念日,一起来看最受读者欢迎的AI技术好书
  • # Swust 12th acm 邀请赛# [ A ] A+B problem [题解]
  • # 手柄编程_北通阿修罗3动手评:一款兼具功能、操控性的电竞手柄
  • # 执行时间 统计mysql_一文说尽 MySQL 优化原理
  • #1015 : KMP算法
  • $(this) 和 this 关键字在 jQuery 中有何不同?
  • (13)Latex:基于ΤΕΧ的自动排版系统——写论文必备
  • (javascript)再说document.body.scrollTop的使用问题
  • (二)测试工具
  • (更新)A股上市公司华证ESG评级得分稳健性校验ESG得分年均值中位数(2009-2023年.12)