Webpack
Posted 桉森屿夏
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Webpack相关的知识,希望对你有一定的参考价值。
13、Webpack
WebPack 是一款模块加载器兼打包工具,它能把各种资源,如 JS、JSX、ES6、SASS、LESS、图片等都作为模块来处理和使用.
npm install webpack -g
npm install webpack-cli -g
测试安装成功: 输入以下命令有版本号输出即为安装成功
webpack -v
webpack-cli -v
13.1、什么是Webpack
本质上,webpack是一个现代javascript应用程序的静态模块打包器(module bundler)。当webpack处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个bundle.
Webpack是当下最热门的前端资源模块化管理和打包工具,它可以将许多松散耦合的模块按照依赖和规则打包成符合生产环境部署的前端资源。还可以将按需加载的模块进行代码分离,等到实际需要时再异步加载。通过loader转换,任何形式的资源都可以当做模块,比如CommonsJS、AMD、ES6、 CSS、JSON、CoffeeScript、LESS等;
伴随着移动互联网的大潮,当今越来越多的网站已经从网页模式进化到了WebApp模式。它们运行在现代浏览器里,使用html5、CSS3、ES6 等新的技术来开发丰富的功能,网页已经不仅仅是完成浏览器的基本需求;WebApp通常是一个SPA (单页面应用) ,每一个视图通过异步的方式加载,这导致页面初始化和使用过程中会加载越来越多的JS代码,这给前端的开发流程和资源组织带来了巨大挑战。
前端开发和其他开发工作的主要区别,首先是前端基于多语言、多层次的编码和组织工作,其次前端产品的交付是基于浏览器的,这些资源是通过增量加载的方式运行到浏览器端,如何在开发环境组织好这些碎片化的代码和资源,并且保证他们在浏览器端快速、优雅的加载和更新,就需要一个模块化系统,这个理想中的模块化系统是前端工程师多年来一直探索的难题。
13.2、使用Webpack
- 先创建一个包 交由idea打开 会生成一个.idea文件 那么就说明该文件就交由idea负责
- 在idea中创建modules包,再创建hello.js,hello.js 暴露接口 相当于Java中的类
//暴露一个方法
exports.sayHi = function ()
document.write("<h1>狂神说ES6</h1>>")
- 创建main.js 当作是js主入口 , main.js 请求hello.js 调用sayHi()方法
var hello = require("./hello");
hello.sayHi()
-
在主目录创建webpack-config.js , webpack-config.js 这个相当于webpack的配置文件
enrty请求main.js的文件
output是输出的位置和名字
module.exports = entry: './modules/main.js', output: filename: './js/bundle.js'
-
在idea命令台输入
webpack
命令(idea要设置管理员启动) -
完成上述操作之后会在主目录生成一个dist文件 生成的js文件夹路径为/ dist/js/bundle.js
-
在主目录创建index.html 导入bundle.js
index.html<html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <script src="dist/js/bundle.js"></script> </head> <body> </body> </html>
# Webpack 学习Webpack 搭建 Vue项目
Webpack 学习、Webpack 搭建 Vue项目
文章目录
- Webpack 学习、Webpack 搭建 Vue项目
Webpack、Webpack-cli、vue-cli
webpack
打包工具webpack-cli
是webpack
的命令行接口vue-cli
,是vue
基于webpack
生态搞的上层封装,为快速开发vue
应用提供帮助
Webpack 介绍
Webpack
是一个前端的项目构建工具,它是基于node.js
开发出来的一个前端工具,当webpack
处理应用程序时,它会递归地构建一个依赖关系图,其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个bundle
。- 官方手册:概念 | webpack 中文文档 (docschina.org)
入口
webpack
打包的起点,可以有一个或多个,一般是js
文件。webpack
会从起点文件开始,寻找起点直接或间接依赖的其它所有的依赖,包括JS
、CSS
、图片资源等,作为将来打包的原始数据
输出
- 出口一般包含两个属性:
path
和filename
。用来告诉webpack
打包的目标文件夹,以及文件的名称。目的地也可以有多个。
加载器loader
webpack
本身只识别Js
文件,如果要加载非JS
文件,必须指定一些额外的加载器(loader
),例如css-loader
。然后将这些文件转为webpack
能处理的有效模块,最后利用webpack
的打包能力去处理。
加载器使用步骤
- 安装相对应的
loader
加载器(依赖的模块) - 安装完对应的
loader
加载器之后,在Webpack.config.js
配置文件中配置相对应的匹配规则 - 如果有依赖的
CSS
或者其它文件,都以import
命令的方式在入口js
文件里面引入
loader处理样式表
- 打包处理
CSS
文件
npm i style-loader css-loader -D
- 在
webpack.config.js
配置文件里面新增module
节点对象,在这个module
对象身上,有个rules
属性数组,这个数组中,存放了所有的第三方文件爱你的匹配和处理规则。
// 用来配置所有第三方模块加载器
module:
// 配置第三方模块的匹配规则
rules:[
// 配置处理 .css文件的第三方loader规则
test:/\\.css$/,use:['style-loader','css-loader']
]
- 在
main.js
入口文件里面引入CSS
文件即可成功使用
import './css/index.css'
loader处理URL地址
-
默认情况下,
Webpack
无法处理CSS
文件中的URL
地址,无论是图片还是字体库,只要是URL
,都处理不了 -
通过安装
url-loader file-loader
插件来对URL
进行处理
npm i url-loader file-loader -D
-
在
webpack.config.js
文件里面配置URL
的处理规则 -
limit
:图片的大小,单位是byte
,如果引用的图片大于给定的limit
值,则不会被转为base64
格式的字符串, 如果 图片小于给定的 limit 值,则会被转为base64
的字符串 -
name
:设置URL指定的路径名,默认会以hash
值来命名(防止重名),可以通过如下方式通过hash值拼图片原始名的方式来达到同样的效果,且辨识度更高
//URL图片路径的匹配规则
test:/\\.(jpg|jepg|png|gif)$/,
use:[loader:'file-loader',
options:
name: 'images/[name].[ext]',
esModule: false //很重要,否则<img ur="[object Module]">依然无法显示图片
]
,
//字体图标的匹配规则
test:/\\.(eot|svg|woff|woff2|ttf)$/,use:'url-loader'
- 效果图
插件
- 插件可以扩展
webpack
的功能,让webpack
不仅仅是完成打包,甚至各种更复杂的功能,或者是对打包功能进行优化、压缩,提高效率。
自定义插件使用
ConsoleLogOnBuildWebpackPlugin.js
,构建开始的时候输出日志
const pluginName = 'ConsoleLogOnBuildWebpackPlugin';
class ConsoleLogOnBuildWebpackPlugin
apply(compiler)
compiler.hooks.run.tap(pluginName, compilation =>
console.log("webpack 构建过程开始!");
);
module.exports = ConsoleLogOnBuildWebpackPlugin;
webpack.config.js
中添加定义的插件
// 导入自定义插件
const ConsoleLogOnBuildWebpackPlugin = require('./ConsoleLogOnBuildWebpackPlugin.js')
// 插件
plugins:[
new ConsoleLogOnBuildWebpackPlugin()
]
模式
-
提供
mode
配置选项,告知 webpack 使用相应模式的内置优化。 -
在配置中提供
mode
选项:
module.exports =
mode: 'production'
;
或者从 CLI
参数中传递:
webpack --mode=production
webpack-dev-server
- 每次修改任何
js
或css
内容,都必须重新打包,非常麻烦。webpack
给我们提供了一个插件,可以帮我们运行一个web
服务,加载页面内容,并且修改js
后不需要重新加载就能看到最新结果 webpack-dev-server
是webpack
官方提供的一个小型服务器。使用它可以为webpack
打包生成的资源文件提供web
服务
主要功能
- 为静态文件提供服务
- 自动刷新和热替换
使用
npm install webpack
npm install webpack-dev-server --save-dev
npm install webpack-cli
- 启动脚本
"scripts":
"dev": "webpack-dev-server --mode development --hot --open --port 4444 --host 127.0.0.1 --config ./build/webpack.config.js"
Webpack 排除依赖
Webpack 打包分析插件使用
- 安装
webpack-bundle-analyzer:
npm install webpack-bundle-analyzer --save-dev
- 配置
webpack.config.js
文件:
// 插件
plugins:[
// 打包分析插件
new BundleAnalyzerPlugin()
]
- 启动服务之后查看
Webpack 打包排除依赖
webpack.config.js
配置
// 表示jquery不需要打包
externals:
jquery: 'jQuery',
,
- 排除前
- 排除后
补充知识点
npm install
npm install module_name -S
即npm install module_name –save
写入dependencies
npm install module_name -D
即npm install module_name –save-dev
写入devDependencies
npm install module_name -g
全局安装(命令行使用)
npm install module_name
本地安装(将安装包放在./node_modules
下)
dependencies
与devDependencies
区别
devDependencies
里面的插件只用于开发环境,不用于生产环境dependencies
是需要发布到生产环境的
Webpack处理第三方文件类型的过程
- 校验文件名,如果是
js
文件直接打包 - 非
js
文件,去webpack.config.js
里面找对应匹配规则 - 找到则调用规则打包,否则报错
rules
的use
规则数组从右到左调用,会将后面调用完毕的处理结果交给前面的规则继续处理- 调用完毕之后会将处理结果直接交给
Webpack
进行打包合并,最终输出到bundle.js
中去
Webpack 中使用 Vue
Vue 基本使用方式
- 通过
script
标签引入vue.js
文件 - 在
body
中声明一个盒子,并且为它设置一个id
属性 - 在
script
标签中通过new Vue()
创建一个VM
实例
包的查找规则
- 使用
import
命令导入模块中的一个包的时候,是怎么查找的 - 找项目中的
node_modules
文件夹 - 在
node_modules
文件夹中找到对应的包名 - 在
package.json
的配置文件里,找到main
属性,main
属性指定了这个包在被加载的时候的入口文件
使用 Vue
普通vue工程
- 安装一下依赖
// vue
"vue": "^2.7.10",
// vue 页面解析器
"vue-loader": "^15.10.0",
// vue 样式解析器
"vue-style-loader": "^4.1.3",
// vue-template-compiler是编译vue模板的包,传入模板返回AST抽象语法树
"vue-template-compiler": "^2.7.10"
- ``index.html`创建容器
<!-- vue 容器 -->
<div id="app"></div>
main.js
创建vue
对象、挂载到DOM
元素上
//使用vue进行开发
import Vue from 'vue'
import App from './vue/App.vue'
new Vue(
el: '#app',
template: '<App/>',
components: App
)
- 编写
App.vue
<template>
<div id="one">text</div>
</template>
<script>
export default
data ()
return
text: 'Vue hello world!'
</script>
<style scoped>
#one
border: 1px solid red;
</style>
- 配置
.vue
文件解析规则
// vue 插件
const VueLoaderPlugin = require('vue-loader')
// vue 处理规则
test: /\\.vue$/, use:['vue-loader']
// vue 处理规则
test: /\\.vue$/, use:['vue-loader']
- 启动服务测试
Vue 路由使用
- 安装依赖
npm i vue-router -D
-
编写两个测试页面
vue-one
和vue-two
-
router.js
定义 路由信息
import Vue from 'vue'
// 1. 导入 vue-router 包
import Router from 'vue-router'
Vue.use(Router )
// 2、导入组件
import VueOne from './vue-one.vue'
import VueTwo from './vue-two.vue'
// 3. 创建路由对象并且导出
export default new Router (
routes: [
// account goodslist
path: '/one', component: VueOne ,
path: '/two', component: VueTwo
]
)
main.js
挂载
//使用vue进行开发
import Vue from 'vue'
import App from './vue/App.vue'
// 导入 vue router
import router from './vue/router.js'
new Vue(
el: '#app',
template: '<App/>',
components: App ,
router
)
App.vue
绑定Dom
对象
<div id="one">text
<router-view />
</div>
- 访问路由展示如下:
报错问题
webpack
配置文件后运行报错TypeError: VueLoaderPlugin is not a constructor
// "vue-loader": "^17.0.0" 错误引入方法
const VueLoaderPlugin = require('vue-loader/dist/plugin')
// 正确写法
const VueLoaderPlugin = require('vue-loader')
问题二
// 错误写法
test:/\\.css$/,use:['vue-style-loader','style-loader','css-loader'],
// 正确写法 去掉 vue-style-loader
报错原因总结
- 注意各个依赖的版本,基本上都是版本问题
项目说明
- 项目结构
完整Webpack配置
- 配置文件中就是要指定上面说的四个核心概念,入口、出口、加载器、插件。不过,加载器和插件是可选的
webpack.config.js
const path = require('path')
// html 插件
const htmlWebpackPlugin = require('html-webpack-plugin')
// 导入自定义插件
const ConsoleLogOnBuildWebpackPlugin = require('./ConsoleLogOnBuildWebpackPlugin.js')
// vue 插件
const VueLoaderPlugin = require('vue-loader')
// 打包分析插件
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin
module.exports =
// 入口
entry:path.join(__dirname,'../src/main.js'),
// 输出
output:
path:path.join(__dirname,'../dist'),
filename:'bundle.js'
,
// 这个节点,用来配置所有第三方模块加载器
module:
// 配置第三方模块的匹配规则
rules:[
// 配置处理 .css文件的第三方loader规则 从右向左
test:/\\.css$/,use:['style-loader','css-loader'],
test: /\\.less$/,use:[
loader: 'style-loader' ,
loader: 'css-loader',
loader: 'less-loader'
],
test: /\\.scss$/, use: [ loader: "style-loader" , loader: "css-loader" ] ,
// URL图片路径的匹配规则
test:/\\.(jpg|jepg|png|gif)$/,
use:[loader:'file-loader',
options:
name: 'images/[name].[ext]',
esModule: false //很重要,否则<img ur="[object Module]">依然无法显示图片
]
,
// 字体图标的匹配规则
test:/\\.(eot|svg|woff|woff2|ttf)$/,use:'url-loader',
// vue 处理规则
test: /\\.vue$/, use:['vue-loader']
]
,
// 插件
plugins:[
// vue 加载插件
new VueLoaderPlugin(),
// 创建一个在内存中生成html页面的插件
new htmlWebpackPlugin(
//指定模版页面,将来会根据指定的页面路径,去生成内存中的页面
template:path.join(__dirname,'../src/index.html'),
filename:'index.html'
),
// 自定义插件使用
new ConsoleLogOnBuildWebpackPlugin(),
// 打包分析插件
new BundleAnalyzerPlugin()
],
resolve:
alias:
'vue$': 'vue/dist/vue.esm.js' // 'vue/dist/vue.common.js' for webpack 1
,
// 排除依赖
// 表示jquery不需要打包
externals:
// jquery: 'jQuery',
,
完整 package.json
"name": "webpack-server-demo",
"version": "1.0.0",
"description": "",
"main": "/src/index.js",
"scripts":
"test": "echo \\"Error: no test specified\\" && exit 1",
"dev": "webpack-dev-server --mode development --hot --open --port 4444 --host 127.0.0.1 --config ./build/webpack.config.js",
"build": "webpack --mode development --config ./build/webpack.config.js",
"build-analyze": "webpack --config ./build/webpack.config.js --progress"
,
"author": "lidong",
"license": "ISC",
"dependencies":
"jquery": "^3.6.1",
"webpack": "^5.74.0",
"webpack-cli": "^4.10.0",
"webpack-dev-server": "^4.10.0"
,
"devDependencies":
"babel-core": "^6.26.3",
"babel-loader": "^8.2.5",
"css-loader": "^6.7.1",
"file-loader": "^6.2.0",
"html-webpack-plugin": "^5.5.0",
"less-loader": "^11.0.0",
"style-loader": "^3.3.1",
"url-loader": "^4.1.1",
"vue": "^2.7.10",
"vue-loader": "^15.10.0",
"vue-router": "^3.0.1",
"vue-style-loader": "^4.1.3",
"vue-template-compiler": "^2.7.10",
"webpack-bundle-analyzer": "^4.6.1"
源码地址
以上是关于Webpack的主要内容,如果未能解决你的问题,请参考以下文章
webpackwebpack.base.conf.js基础配置