位置: IT常识 - 正文

webpack配置(webpack配置publicpath)

编辑:rootadmin
webpack配置 webpack前端工程化实际的前端开发

推荐整理分享webpack配置(webpack配置publicpath),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:webpack配置文件详解,webpack配置代理,webpack配置完全指南,webpack配置文件详解,webpack配置文件详解,webpack配置代理,webpack配置项有哪些,webpack配置项有哪些,内容如对您有帮助,希望把文章链接给更多的朋友!

模块化(js 的模块化、css 的模块化、资源的模块化)

组件化(复用已有的 UI 结构、样式、行为)

规范化(目录结构的划分、编码规范化、接口规范化、文档规范化、Git 分支管理)

自动化(自动化构建、自动部署、自动化测试)

何为前端工程化

前端工程化即,在企业级的前端项目开发中,把前端开发所需的工具、技术、流程、经验等进行规范化、标准化。这样有利于前端开发自成体系,有一套标准的开发方案和流程。

前端工程化解决方案

早期解决方案:

grunt

gulp

目前主流方案:

webpack

parcel

vite

webpack简介

webpack 是前端的打包工具

打包的工作内容是什么

扫描项目,生成整个项目所有模块的依赖关系,根据配置对模块进行合并,生成一个单独的文件。修改html文件,让html文件引用生成后的文件

将浏览器无法直接识别的(less、sass、ts)文件,转换成浏览器可以实现的内容。

将浏览器暂时无法支持的JS新的语法转换成浏览器可以支持的语法

webpack安装

webpack是基于node.js的,使用前需要安装node

-D 是 --save-dev 的缩写,表示开发时依赖,只在项目开发阶段用到。 -S 是 --save 的缩写,表示运行时依赖,即项目打包发布运行时要用到。

npm初始化

npm init -y

安装webpack

webpack内部还依赖webpack-cli,所以webpack-cli也要安装

npm install --save-dev webpack webpack-cliwebpack - 打包 js

配置

1.创建webpack配置文件 webpack.config.js

// 导入path模块const path = require('path')​// webpack配置module.exports = {    // 配置打包入口文件    entry: path.resolve(__dirname, 'src', 'index.js'),    // 配置打包输出位置,及文件名    output: {        path: path.resolve(__dirname, 'dist'),        // 输出文件名        filename: 'bundle.js'   }}

2.配置webpack执行命令

webpack需要npm来调用才可以执行,在package.json中的script中进行配置

"script":{   "dev":"webpack --config webpack.config.js"}​

经过以上配置,在控制台运行 npm run dev 命令执行 webpack对 js 文件进行打包

webpack - 打包模式

webpack有两种打包模式

development 开发模式

开发模式 :不会对打包生成的文件进行代码压缩和性能优化 打包速度快,适用于开发阶段使用

production 生产模式

生产模式: 会对打包生成的文件进行代码压缩和性能优化 打包速度很慢,仅适合在项目发布阶段使用不设置默认为production模式

配置

在webpack.config.js中添加一个mode配置项

// 导入path模块const path = require('path')​// webpack配置module.exports = {    // ---------------- 打包模式    mode: 'development',       /* // 配置打包入口文件   entry: path.resolve(__dirname, 'src', 'index.js'),   // 配置打包输出位置,及文件名   output: {       path: path.resolve(__dirname, 'dist'),       // 输出文件名       filename: 'bundle.js'     */   }}插件 - html-webpack-plugin

html-webpack-plugin插件可以在每次打包时都创建一个用于测试用的html文件

npm i --save-dev html-webpack-plugin

自定义模板配置webpack.config.js

在默认配置下创建的index.html文件的内容是由html-webpack-html自动生成的。里面除了引入了js外,边最基本的html结构都没有。

可以为html-webpack-html传入一个参数,让html-webpack-html插件,参照某个文件的内容生成html文件

// 导入path模块const path = require('path')​// 导入html-webpack-plugin插件const HtmlWebpackPlugin = require('html-webpack-plugin')​// webpack配置module.exports = {    // ...    // 插件配置    plugins:[        // ---------------- 传入配置参数        new HtmlWebpackPlugin({            // js插入位置            inject: 'body',            // 生成的html文件名            filename: 'index.html',            // 指定参照这个html文件进行生成            template: path.resolve(__dirname, './public/index.html')       })   ]​}webpack - 打包 css

目前为止,仅仅实现了对js文件的打包,这也是webpack默认的功能,还可以对他文件进行打包

打包css传送门

loader

webpack配置(webpack配置publicpath)

打包不同类型文件,要使用不同的loader,loader的作用:

1.读取文件内容。

2.对文件内容进行特定的处理。

下载 style-loader、css-loader

npm i style-loader css-loader --save-dev

配置

css-loader是将css代码从css文件中读取到内存中,而style-loader是将读取到的css代码设置到index.html文件的style标签内

// webpack配置module.exports = {    // ...        // 扩展文件加载模块 - css模块加    module: {        // 由于可以加载多种文件,每种文件对应一种loader,所以是数组        rules: [            // 由于是多种文件,所以使用扩展名进行区分,再应用不同的loader           {                // 正则判断文件类型                test: /\.css$/i,                // 这种类型文件使用以下loader                use: ['style-loader', 'css-loader'],           }       ]   }​}webpack - 打包 less

打包less传送门

下载 less-loader

npm i less-loader --save-dev

配置

// webpack配置module.exports = {    // ...        // 扩展文件加载模块 - css模块加    module: {        // 由于可以加载多种文件,每种文件对应一种loader,所以是数组        rules: [            // 由于是多种文件,所以使用扩展名进行区分,再应用不同的loader           {                // 正则判断文件类型                test: /\.css$/i,                // 这种类型文件使用以下loader                use: ['style-loader', 'css-loader'],           },           {                // 判断less文件                test: /\.less$/i,                // less使用到的loader,                use: [                    "style-loader",                    "css-loader",                    "less-loader"               ]           }       ]   }}webpack - 打包图片

在webpacke5.0中无需下载安装图片对应的loader(模块),因为内嵌了对象图片资源处理的模块,可以直接使用内置的资源模块进行处理(asset/modules) 内置了四种处理图片的资源模块

asset/resource

将图片文件单独打包成一个文件,保存到打包目录,再使用url(file:///d:/xxx/xxx) 就相当于将原图片,复制到了另个新的位置,改了名,url再指向新的位置即可。 之前是通过 file-loader 实现

asset/inline

将图片读取成base64格式,使用时通过url()进行引用 之前是通过 url-loader 实现

asset/source

主要用于字体文件 通过 data:font/woff2;base64,xxxxxoxxox 之前是通过 raw-loader 实现

asset

在asset/resource 与 asset/inline之间自动选择,之前是通过url-loader,并配置资源体积限制实现。

配置

// webpack配置module.exports = {    // ...        // 扩展文件加载模块 - css模块加    module: {        // 由于可以加载多种文件,每种文件对应一种loader,所以是数组        rules: [            // 由于是多种文件,所以使用扩展名进行区分,再应用不同的loader           {                // 正则判断文件类型                test: /\.css$/i,                // 这种类型文件使用以下loader                use: ['style-loader', 'css-loader'],           },           {                // 判断less文件                test: /\.less$/i,                use: [                    "style-loader",                    "css-loader",                    "less-loader"               ]           },           {                // 加载图片资料模板                test: /\.(png|jpg|jpeg|gif|svg)$/,                type: 'asset/resource'           },           {                // 加载字体文件                test: /\.(eot|ttf|otf|woff2)$/,                type: 'asset'           }       ]   }}

测试

1.复制图片资源

创建文件夹 ./src/assets/imgs/ 复制图片到 imgs文件夹内

2.测试:在index.js文件中引入一个图片文件

./src/index.js

// 导入css文件import './assets/css/base.css'​// 导入less文件import './assets/less/index.less'​// 导入一个图片文件import timg from './assets/imgs/timg.png'// 获取页面图片,并设置src属性document.querySelector('.avatar').src = timg

3.测试:在css中设置一个背景图片

./src/assets/less/index.less

body {  // ...​  // .box 盒子  .box{    width: 400px;    height: 300px;    border:1px solid rgba(255,255,255,.5);    margin: 20px auto;    // 设置背景图片    background:url(../imgs/duitang.gif) 0 0/contain no-repeat; } ​}webpack - watch模式

目前为目,每次调整配置,都需要手动重新打包一次。

为了解决这个麻烦,webpack内置watch模块,通过配置可以实现自动打包。 传送门:使用watch模式

package.json配置

"script":{   "watch":"webpack --config webpack.config.js"}

通过npm run watch命令启动 watch 模式

但是这种方式仍然需要手动打开index.html页面,重新打包后,html 页面也不会自动刷新所以

我们会使用 webpack-dev-serve 这个插件来代替这种模式

插件 - webpack-dev-serve

通过webpack的watch模式,已经可以实现自动打包 ,但是这种方式并不完美所以我们将会使用webpack-dev-serve这个插件来代替 watch

下载

npm i --save-dev webpack-dev-server

webpack.config.js配置

// webpack配置module.exports = {    // ...        // webpack-dev-server配置    devServer: {        // 配置站点根目录,默认为输出位置        static: path.resolve(__dirname, 'dist'),        // 设置端口号        port: 8080,        // 自动打开浏览器,访问index.html        open: true   }}

package.json配置启动命令

"script":{   "serve":"webpack --config webpack.config.js"}

启动

npm run serveHMR

webpack-dev-server,还会附带了一个很有用的功能,HMR(hot module replacement) 传送门:模块热替换 在程序运行的过程(不重新启动服务器),动态的添加,替换删除某个模块,而无需重新加载整个页面。 例如:index.less内容修改了,只对这个less模块重新加载,不影响其他模块

// webpack配置module.exports = {    // ...        // webpack-dev-server配置    devServer: {        // 配置站点根目录,默认为输出位置        static: path.resolve(__dirname, 'dist'),        // 设置端口号        port: 4201,        // 自动打开浏览器,访问index.html        open: true,        // 热替换配置,true启用,false禁用,默认为true                ---------在这---------        hot: true   }​}webpack - 打包生产代码

当一个项目开发完毕后,要对项目的代码进行最终的打包,最终的打包,要以production模式进行。

可以修改webpack.config.js中的mode:'production'

// webpack配置module.exports = {    // 打包模式    // 生产环境打包模式    mode: 'production',}

(推荐)也可以在package.json的 script 中配置打包命令,通过--mode=production来指定

"build":{   "serve":"webpack --config webpack.config.js --mode=production"}

打包命令

npm run buildsource map

打包后的代码与原代码的所在的文件名,位置都不相同了,如果出错,可能会很难追踪到错误和警告在源代码中的原始位置。可以使用source map,source map可以将错误在源代码中的显示给我们。只在开发阶段使用,上线一定要移除

// webpack配置module.exports = {    // 配置source-map    devtool: 'source-map',        // ...}

注意

生产环境打包之前一定要移除,不然就会被坏人看到代码喽!!!

本文链接地址:https://www.jiuchutong.com/zhishi/299484.html 转载请保留说明!

上一篇:vue如何请求后端数据(vue请求后端接口)

下一篇:seaborn库学习----分布图displot、histplot、kdeplot、ecdfplot(seaborn库的特点)

  • 支持苹果笔的ipad(支持苹果笔的ipad型号)

    支持苹果笔的ipad(支持苹果笔的ipad型号)

  • 微信收款简报可以消除记录吗(微信收款简报顾客管理怎么删除)

    微信收款简报可以消除记录吗(微信收款简报顾客管理怎么删除)

  • 手机屏幕发黄是什么原因造成的(手机屏幕发黄是质量问题吗)

    手机屏幕发黄是什么原因造成的(手机屏幕发黄是质量问题吗)

  • 10.5寸ipad长宽是多少厘米(10.5英寸ipad长宽)

    10.5寸ipad长宽是多少厘米(10.5英寸ipad长宽)

  • 为什么小红书发布的内容别人看不到(为什么小红书发不了评论)

    为什么小红书发布的内容别人看不到(为什么小红书发不了评论)

  • 苹果全屏手机有哪几款(苹果全屏是什么型号)

    苹果全屏手机有哪几款(苹果全屏是什么型号)

  • oppo突然不闪充了(oppo手机闪充突然不闪充了怎么回事)

    oppo突然不闪充了(oppo手机闪充突然不闪充了怎么回事)

  • 微信举报是匿名的吗(微信举报匿名能查到微信两位个号)

    微信举报是匿名的吗(微信举报匿名能查到微信两位个号)

  • 电脑固态是什么意思啊(移动硬盘固态和机械的哪个好)

    电脑固态是什么意思啊(移动硬盘固态和机械的哪个好)

  • 删除备份有什么影响吗(删除备份还能恢复吗)

    删除备份有什么影响吗(删除备份还能恢复吗)

  • 怎么让电脑恢复到某个时间前(怎么让电脑恢复上一次正常操作)

    怎么让电脑恢复到某个时间前(怎么让电脑恢复上一次正常操作)

  • 荣耀play3电池多少毫安(荣耀play3电池多大)

    荣耀play3电池多少毫安(荣耀play3电池多大)

  • 光纤一分二能用两个光猫吗(光纤一分二能用两个光猫 影响网速)

    光纤一分二能用两个光猫吗(光纤一分二能用两个光猫 影响网速)

  • qq免打扰了还能qq电话吗(qq免打扰会怎么样)

    qq免打扰了还能qq电话吗(qq免打扰会怎么样)

  • 关闭windows7窗口的方法(关闭windows7的窗口的方法)

    关闭windows7窗口的方法(关闭windows7的窗口的方法)

  • 苹果6 6s 6plus的区别(苹果六6plus)

    苹果6 6s 6plus的区别(苹果六6plus)

  • word封面文字竖排居中(word封面文字竖排居中间距)

    word封面文字竖排居中(word封面文字竖排居中间距)

  • 全民k歌访客在哪里看(全民k歌查看全部访客)

    全民k歌访客在哪里看(全民k歌查看全部访客)

  • iphone7电池寿命多少换(iphone7电池使用时间)

    iphone7电池寿命多少换(iphone7电池使用时间)

  • 微信怎么隐藏电话号码(微信怎么隐藏电话号)

    微信怎么隐藏电话号码(微信怎么隐藏电话号)

  • word怎么设置整页底纹 (word怎么设置整个文档字体)

    word怎么设置整页底纹 (word怎么设置整个文档字体)

  • 小米手环1代怎么开机(小米手环1代怎么重置)

    小米手环1代怎么开机(小米手环1代怎么重置)

  • id卡和ic卡的区别(ic id 卡区别)

    id卡和ic卡的区别(ic id 卡区别)

  • 三星s7eage和s8有什么区别(三星s7s8对比)

    三星s7eage和s8有什么区别(三星s7s8对比)

  • 与大数据密切相关的技术是(大数据密切相关的技术是什么)

    与大数据密切相关的技术是(大数据密切相关的技术是什么)

  • 钉钉抄送人是干嘛用的(钉钉抄送人应该选谁)

    钉钉抄送人是干嘛用的(钉钉抄送人应该选谁)

  • 探探为什么收不到信息(探探为什么收不了验证码)

    探探为什么收不到信息(探探为什么收不了验证码)

  • 小米手机闹钟怎么设置语音播报(小米手机闹钟怎么取消闹铃)

    小米手机闹钟怎么设置语音播报(小米手机闹钟怎么取消闹铃)

  • iphone8自拍反向能改吗(苹果8自拍取消反向)

    iphone8自拍反向能改吗(苹果8自拍取消反向)

  • 赠送给客户的库存商品怎么做账
  • 增值税发票超过3个月可以作废吗
  • 财税咨询
  • 行政事业单位决算编制流程图
  • 发票上税额加不上怎么办
  • 公允价值模式下,投资性房地产不计提折旧或摊销
  • 被客户扣钱怎么办
  • 怎么快速金蝶数据入库
  • 收到加工费普通发票怎么做账务处理
  • 汇算清缴报告和审计报告有什么区别
  • 公司账外现金
  • 个人承包承租转包转租取得的所得
  • 高新企业如何结转成本
  • 固定资产后续支出的确认和处理
  • 收到去年所得税汇算清缴退税账务处理
  • 受托方提供材料怎么写
  • 资产损失类型有哪些
  • 结转库存什么意思
  • 托收承付销售货物什么意思
  • 运费营改增时间
  • 房地产开发企业预收款预缴增值税
  • 员工私人车通行费能抵进项税吗
  • 小规模企业如何
  • 对公账户钱怎么退回去
  • 购车装修能不能算固定资产
  • 发票月初抄税流程
  • 外购商品用于招待怎么做账
  • 出口货物免抵退申报明细录入怎么填
  • 基金管理人收取回扣
  • 小规模建筑公司可以开劳务发票吗
  • 机打发票验旧是什么意思
  • 加工贸易企业如何财务管理账务流程
  • 现金日记账如何结账
  • 合同付款会计分录
  • 车间机物料消耗属于间接生产费用吗
  • 未开票收入跨年度如何申报冲回
  • 苹果Mac系统怎么切换输入法
  • 劳务费和服务费税率一样吗
  • 公司为员工发放生日福利
  • 调整以前年度亏损
  • 勃朗峰峡谷
  • 采用汇兑的方式归还前欠货款
  • 申报个人所得税是按应发工资还是实发工资
  • php实现搜索的方式
  • 冲红的销项税怎么结转
  • vue做项目的流程
  • 遗传算法排课代码python
  • push指令执行的详细过程
  • 原材料的采购成本主要包括有?
  • mkv视频制作
  • phpcms安装
  • 年金终值系数表值系数
  • 报废的机器设备属于什么会计要素
  • 年报中的资产总额怎么计算
  • 原材料的采购成本包括哪些
  • 汽车属于固定资产类吗
  • 4s店出售试驾车账务处理
  • 小规模纳税人增值税计算公式
  • 库存商品发出计价测试
  • 法人存入公司账户会计分录
  • sql局部变量标识符
  • linux中安装vim命令
  • vmware虚拟机步骤
  • freebsd 安装
  • WINDOWS操作系统支持的文件系统主要有三种类型
  • win7的系统设置
  • 图片加载完成再加载
  • javascript事件模型介绍
  • dos命令中删除文件命令有哪些
  • 怎么用html做一个留言板
  • python 中的列表
  • Javascript this 关键字 详解
  • js new实现
  • 黑龙江地方税务总局官网
  • 上海市个人所得税计算
  • 重庆购房退契税
  • 纳税人接受教育
  • 开票盘注销后能否撤回
  • 上海长宁区多大面积
  • 加油的增值税发票可以抵扣吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设