IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 每天一个前端小知识01——Webpack -> 正文阅读

[JavaScript知识库]每天一个前端小知识01——Webpack

一、何为前端工程化

1.模块化:包括对css、js、资源的模块化

2.组件化:封装组件,复用ui、css、js

3.规范化:目录结构、编码、接口、文档以及git分支

4.自动化:自动化构建、部署、测试

二、Webpack快速入门

webpack 是目前前端工程化的最流行的解决方案之一
特点:模块化开发、代码压缩混淆、兼容性、性能优化等

如何新建webpack简单项目?

1.新建项目目录,npm init –y,初始化包管理配置文件 package.json
2.新建 src 源代码目录
3.新建 src -> index.html 首页和 src -> index.js 文件
4.npm install webpack webpack-cli -D
5.在项目根目录中,创建名为 webpack.config.js 的 webpack 配置文件
6.package.json 的 scripts 节点下,新增 dev 脚本
7. 在终端中运行 npm run dev 命令,启动 webpack 进行项目的打包构建

在这里插入图片描述
在这里插入图片描述

如何配置webpack?

1.mode 的可选值:development和production
2. webpack.config.js 文件的作用:webpack.config.js 是 webpack 的配置文件,打包之前,会先读取此文件的配置
3.  webpack 中的默认约定:默认的打包入口文件为 src -> index.js,默认的输出文件路径为 dist -> main.js
4.  自定义打包的入口与出口:通过 entry 节点指定打包的入口。通过 output 节点指定打包的出口。

在这里插入图片描述

三、Webpack插件

1.webpack-dev-server(热更新):每当修改了源代码,webpack 会自动进行项目的打包和构建

npm install webpack-dev-server
修改 package.json
修改 webpack.config.js

在这里插入图片描述
在这里插入图片描述

2.html-webpack-plug(自定制 index.html 页面):将 src 目录下的 index.html 首页,复制到项目根目录中一份

npm install html-webpack-plugin

在这里插入图片描述

四、Webpack Loader

webpack 默认只能处理以 js ,其他需要调用 loader 加载器才可以处理, loader 调用顺序后往前

1.css-loader:打包处理 css

npm i style-loader css-loader -D
在 webpack.config.js 的 module -> rules 数组中,添加 loader 规则

在这里插入图片描述

2.less-loader:打包处理 less

npm i less-loader less -D
在 webpack.config.js 的 module -> rules 数组中,添加 loader 规则

在这里插入图片描述

3.url-loader:打包处理image

npm i url-loader file-loader -D
在 webpack.config.js 的 module -> rules 数组中,添加 loader 规则

在这里插入图片描述

4.babel-loader:打包处理 webpack 无法处理的高级 JS

npm i babel-loader @babel/core @babel/plugin-proposal-decorators -D
在 webpack.config.js 的 module -> rules 数组中,添加 loader 规则
在项目根目录下,创建名为 babel.config.js 的配置文件,定义 Babel 的配置项

	module.exports = {
		plugins:[['@babel/plugin-proposal-decorators',{ legacy: true }]]
	}

在这里插入图片描述

五、Webpack 打包

为什么要打包发布?

开发环境下,打包生成的文件存在内存中,无法获取到最终打包生成的文件
开发环境下,打包生成的文件不会进行代码压缩和性能优化

配置 webpack 的打包发布

package.json 文件的 scripts 节点下,新增 build 命令

在这里插入图片描述
统一生成文件js和image文件夹

在 webpack.config.js 配置文件的 output 节点中
修改 webpack.config.js 中的 url-loader 配置项,新增 outputPath 选项

在这里插入图片描述
在这里插入图片描述
自动清理 dist 目录

安装并配置 clean-webpack-plugin

在这里插入图片描述

六、Source Map

何为 Source Map

Source Map 就是一个信息文件,里面储存着代码位置信息

解决默认 Source Map

在 webpack.config.js 中添加如下的配置

在这里插入图片描述
生产环境下的 Source Map

定位报错的具体行数,且不想暴露源码。此时可以将 devtool 的值设置为nosources-source-map
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-09-04 01:02:48  更:2022-09-04 01:05:37 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 14:16:19-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码