技术标签: webpack 前端 javascript
模块化(js 的模块化、css 的模块化、资源的模块化)
组件化(复用已有的 UI 结构、样式、行为)
规范化(目录结构的划分、编码规范化、接口规范化、文档规范化、Git 分支管理)
自动化(自动化构建、自动部署、自动化测试)
前端工程化即,在企业级的前端项目开发中,把前端开发所需的工具、技术、流程、经验等进行规范化、标准化。这样有利于前端开发自成体系,有一套标准的开发方案和流程。
早期解决方案:
目前主流方案:
webpack 是前端的打包工具
打包的工作内容是什么
扫描项目,生成整个项目所有模块的依赖关系,根据配置对模块进行合并,生成一个单独的文件。修改html文件,让html文件引用生成后的文件
将浏览器无法直接识别的(less、sass、ts)文件,转换成浏览器可以实现的内容。
将浏览器暂时无法支持的JS新的语法转换成浏览器可以支持的语法
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-cli
配置
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有两种打包模式
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文件
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') }) ] }
目前为止,仅仅实现了对js文件的打包,这也是webpack默认的功能,还可以对他文件进行打包
loader
打包不同类型文件,要使用不同的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'], } ] } }
下载 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" ] } ] } }
在webpacke5.0中无需下载安装图片对应的loader(模块),因为内嵌了对象图片资源处理的模块,可以直接使用内置的资源模块进行处理(asset/modules) 内置了四种处理图片的资源模块
asset/resource
将图片文件单独打包成一个文件,保存到打包目录,再使用url(file:///d:/xxx/xxx) 就相当于将原图片,复制到了另个新的位置,改了名,url再指向新的位置即可。 之前是通过
file-loader
实现
asset/inline
将图片读取成base64格式,使用时通过url(data:image/png;base64,xxxxx)进行引用 之前是通过
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模块,通过配置可以实现自动打包。 传送门:使用watch模式
package.json配置
"script":{ "watch":"webpack --config webpack.config.js" }
通过npm run watch
命令启动 watch 模式
但是这种方式仍然需要手动打开index.html页面,重新打包后,html 页面也不会自动刷新所以
我们会使用 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 serve
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 } }
当一个项目开发完毕后,要对项目的代码进行最终的打包,最终的打包,要以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 build
打包后的代码与原代码的所在的文件名,位置都不相同了,如果出错,可能会很难追踪到错误和警告在源代码中的原始位置。可以使用source map,source map可以将错误在源代码中的显示给我们。只在开发阶段使用,上线一定要移除
// webpack配置 module.exports = { // 配置source-map devtool: 'source-map', // ... }
注意
生产环境打包之前一定要移除,不然就会被坏人看到代码喽!!!
文章浏览阅读3.2w次,点赞29次,收藏203次。目录简介参考Snap7 简介Snap7 用途适用系统支持语言西门子S7通信介绍Snap7 组件Sanp7 APISnap7 PythonSnap7 安装PLC设置连接PLC读取数据发送数据Sanp7 C/C++node.js简介最近在开发一个项目,作为技术帝,已经完成工艺、机械设计的设计,项目过多,也是为了让自己更加????叉,就开始尝试做电气制图和PLC编程。结合物联网的发展,有一种想法,将数据传..._snap7官网
文章浏览阅读554次,点赞2次,收藏6次。HashMap原理:HashMap主要由数组和链表组成,他不是线程安全的。核心的点就是put插入数据的过程,get查询数据以及扩容的方式。put元素: 在put插入的时候会根据key的hashcode去做hash运算得到一个index值(利用元素key的哈希值对数组长度-1按位与操作得到,为什么不用取模%运算呢?因为java的%比位运算慢10倍左右),根据index值放入数组的相应位置。每一个节点(Node)都会保存自身的hash、key、value、以及下个节点为什么要有链表: 因为不同的key可_concurrent hash map,在jdk1.7和1.8的底层原理有什么区别,为什么1.8要做出这
文章浏览阅读3.5w次。图文记录苹果开发者账号(公司级)和邓白氏编码(D-U-N-S)申请流水过程申请于2015.05-06份,算是较新的版本,有需要可以参考下_legal entity name d-u-n-s庐 number
文章浏览阅读1.1k次,点赞2次,收藏8次。哎呀我的妈妈咪呀,我来讲讲我为啥要写这篇文章。我tm之前用IDEA写Java 电脑项目习惯了,创建项目的时候就直接 新建项目,然后Java > Maven啥的,弄一大堆,然后写好页面和Servlet之后运行tomcat之后,用localhost:8080/项目名称/servlet名直接是找不到资源,搞我心态搞了现在tmb一个月,现在我总算明白了,那个初始模板可能有些插件/模块啥的自己不知道引用哪些,所以先开始总是报红,然后在web.xml里面写也tmd爆红,我真是服了!_idea2023社区版提供web开发吗
文章浏览阅读2w次,点赞9次,收藏49次。引言:黑盒测试是从软件的外部对软件实施测试,也常形容为闭着眼睛测试。在接下来的学习中将介绍几种常用的黑盒测试方法,其中包括等价类划分、边界值分析、决策表测试等。1. 等价类划分测试等价类划分是一种典型的黑盒测试方法,该方法完全不考虑程序的内部结构,只根据对软件的要求和说明,即需求规格说明,把程序输入域划分成若干个部分,然后从每个部分中选取少数有代表性的数据作_一个循环条件为≤时,却错误写成<,用哪种测试方法能够找到这个错误
文章浏览阅读227次。通过对等事务复制可以在拓扑中的任何节点插入、更新或删除数据并将数据更改传播到其他节点。由于可在任何节点上更改数据,因此在不同节点上进行的数据更改可能会相互冲突。如果在多个节点上修改了某一行,则将该行传播给其他节点时可能会导致冲突..._对等冲突检测错误
文章浏览阅读7.5k次,点赞3次,收藏12次。浮点数不能精确的表示十进制数,并且即使是最简单的数学运算也会产生误差。该错误是由于浮点数的存储方式引起的。_python float 精度
文章浏览阅读1.3w次,点赞21次,收藏115次。HT合泰单片机入门教程系列文章目录前言一、合泰单片机的优势二、HT-IDE3000安装1.HT-IDE3000下载2.HT-IDE3000安装总结系列文章目录# 第一章 HT单片机环境搭建目录系列文章目录前言一、合泰单片机的优势二、HT-IDE3000安装1.HT-IDE3000下载2.HT-IDE3000安装总结前言工作已经很长一段时间,虽然还是菜鸟一只。但还是有点心得体会。写合泰单片机系列教程的原因:一、是为了记录自己学习过程和学习经历(ps:当初毕业进公司接触到的第一个就是为一款已_合泰单片机入门教程
文章浏览阅读7.1k次。传感器是第二代智能手机的重要标志之一。可以毫不客气地说,现在市面上的Android手机和平板电脑(TV除外)都内置了传感器。否则很多游戏和应用就无法使用了。Android SDK支持的传感器并不是每一部Android设备都支持所有的传感器。大多数Android设备只支持一部分传感器。例如,方向传感器(电子罗盘)、重力传感器(屏幕翻转、赛车游戏等)。动作(Motion)传感器环境(E_导出智能手机中的传感器数据
文章浏览阅读6.4k次,点赞2次,收藏16次。背景**基于公司已给出的结果上做出调整(公司只给出了top10),画KEGG富集通路的气泡图,初始文件如下图代码演示> getwd() #显示工作目录> setwd() #如果上述显示不是想要的路径,可以新建一个文件夹然后设置成工作目录,方便一些原始文件以及结果图片的存放> install.packages("ggplot2",destdir="D:/RData/R-win-4.0.2/R-4.0.2/R-packages",lib="D:/RData/R-win-4.0.2_ggplot 高低通路kegg
文章浏览阅读2.3k次。简介实际上,所有的前台程序都可以分为View以及Model两个层次,Model层使用字面量以及JS特性创建数据模型,并搭载用户数据,View层则以用户友好的方式呈现Model层数据,并提供友好的交互方式。那么如何连接View和Model这两个层次呢?如果写过J2EE程序,那么最经典的连接方式就是MVC模式了,通过控制器进行View以及Model的交互。而另一种异军突起的方式,则是MVVM了,使_vue innerhtml $
文章浏览阅读277次,点赞4次,收藏4次。深度学习人脸识别:InsightFace-REST 全方位解析项目地址:https://gitcode.com/SthPhoenix/InsightFace-RESTInsightFace-REST 是一个基于深度学习的人脸识别 RESTful API 服务,它提供了一个简洁而强大的接口,使得开发者能够轻松地在自己的应用中集成高精度的人脸检测、识别和属性分析功能。项目概述InsightFa...