Vue(基础七)_webpack使用工具(下)
一、前言
1、webpack.config文件配置
2、webpack打包css文件
3、webpack配置打包img文件
4、编译less文件
5、webpack将index.html 和build.js编译到同一个文件夹
二、主要内容
1、webpack.config文件配置
webpack 在执行时除了用webpack xxxx.js xxxx.js 这种形式,还可以用配置文件的形式,默认会搜索当前文件下的webpack.config.js这个文件,
(1)webpack.config.js文件基本配置
//传统方式 //webpack ./main.js ./build.js
module.exports = {
//入口文件
entry:{
"main":'./main.js' //可以有多个,也可以有一个,如果有一个就默认从这个入口开始分析
},
//出口文件
output:{
filename:'./build.js'
},
watch:true,//文件监听是否有改动,有就会自动产出build.js文件
}
(2)有时候我们需要分别执行生产环境和开发环境,分别监听出口文件,需要再额外添加两个文件如下:
第一步:

两个文件分别加如下代码:
webpack.dev.config.js
// webpack ./main.js ./build.js
module.exports = {
// 入口
entry:{
// 可以有多个入口,也可以有一个,如果有一个就默认从这一个入口开始分析
"main":'./main.js'
},
output:{
filename:'./build.js'
},
watch:true,//文件监视改动 自动产出build.js
}
webpack.prod.config.js
// webpack ./main.js ./build.js
module.exports = {
// 入口
entry:{
// 可以有多个入口,也可以有一个,如果有一个就默认从这一个入口开始分析
"main":'./main.js'
},
output:{
filename:'./build.js'
}
}
第二步:上面加的两个文件只是普通的.js文件,执行的时候需要按照如下执行,才会识别
webpack --config ./webpack.dev.config.js
第三步:我们也可以到package.json中添加如下
"scripts": {
"dev":"webpack --config ./webpack.dev.config.js",
"prod":"webpack --config ./webpack.prod.config.js"
}
第四步:执行的时候就可以按照
npm run dev npm run prod
--------------------------------------------------------------------------------------------------------------------------------------------
2、webpack打包css文件
(1)建立的工程目录如下

(2)App.js main.js main.css 代码如下
import './main.css'
// es6 Module
import Vue from './vue.js'
// 整个项目的入口文件
import App from './App.js' new Vue({
el:'#app',
components:{
App
},
template:`
<App />
`
});
main.js
body{
background-color: green;
}
main.css
var App = {
template:'<div>我是一个入口组件</div>'
};
export default App;
App.js
(3)在打包css文件的时候需要安装插件 css-loader style-loader 在控制台执行如下命令下载安装
cnpm install css-loader style-loader -D
(4)此时package.json文件内容如下
{
"name": "css-loader1",
"version": "1.0.0",
"description": "",
"main": "main.js",
"scripts": {
"dev": "webpack --config ./webpack.dev.config.js",
"prod": "webpack --config ./webpack.prod.config.js"
},
"keywords": [],
"author": "",
"license": "ISC",
"devDependencies": {
"css-loader": "^2.1.1",
"style-loader": "^0.23.1"
}
}
(5)安装好了之后需要在webpack.dev.congfig.js文件中配置
// webpack ./main.js ./build.js
module.exports = {
// 入口
entry:{
// 可以有多个入口,也可以有一个,如果有一个就默认从这一个入口开始分析
"main":'./main.js'
},
output:{
filename:'./build.js'
},
watch:true,//文件监视改动 自动产出build.js
// 声明模块
// 包含各个loader
module:{
loaders:[
{
// /遇到后缀为.css的文件,webpack先用css-loader加载器去解析这个文件
// 最后计算完的css,将会使用style-loader生成一个内容为最终解析完的css代码的style标签,放到head标签里。
// webpack在打包过程中,遇到后缀为css的文件,就会使用style-loader和css-loader去加载这个文件。
test:/\.css$/,
loader:'style-loader!css-loader'
} ]
}
}
(6)运行npm run dev,后并在index.html 中引入生成的出口文件build.js

3、webpack配置打包img文件
(1)项目目录结构

(2)main.js App.js文件代码如下
// es6 Module
import Vue from './vue.js'
// 整个项目的入口文件
import App from './App.js' new Vue({
el:'#app',
components:{
App
},
template:`
<App />
`
});
main.js
import imgSrc from './1.jpg'
export default {
template:`
<div>
<img :src="imgSrc" alt="" />
</div>
`,
data(){
return {
imgSrc:imgSrc
}
}
};
App.js
(3)打包图片需要安装url-loader file-loader,执行如下命令下载
npm install url-loader file-loader -D
(4)此时package.json文件
{
"name": "css-loader1",
"version": "1.0.0",
"description": "",
"main": "main.js",
"scripts": {
"dev": "webpack --config ./webpack.dev.config.js",
"prod": "webpack --config ./webpack.prod.config.js"
},
"keywords": [],
"author": "",
"license": "ISC",
"devDependencies": {
"css-loader": "^2.1.1",
"file-loader": "^3.0.1",
"style-loader": "^0.23.1",
"url-loader": "^1.1.2"
}
}
(5)需要在webpack.config文件下
// webpack ./main.js ./build.js
module.exports = {
// 入口
entry:{
// 可以有多个入口,也可以有一个,如果有一个就默认从这一个入口开始分析
"main":'./main.js'
},
output:{
filename:'./build.js'
},
watch:true,//文件监视改动 自动产出build.js
// 声明模块
// 包含各个loader
module:{
loaders:[
{
// /遇到后缀为.css的文件,webpack先用css-loader加载器去解析这个文件
// 最后计算完的css,将会使用style-loader生成一个内容为最终解析完的css代码的style标签,放到head标签里。
// webpack在打包过程中,遇到后缀为css的文件,就会使用style-loader和css-loader去加载这个文件。
test:/\.css$/,
loader:'style-loader!css-loader'
},
{
test:/\.(jpg|png|jpeg|gif|svg)$/,
loader:'url-loader?limit = 3000'
} ]
}
}
注意点:当你图片的大小大于你这里设置的大小的时候,会生成一张额外的图片, 当你的图片大小小于你上面的大小引入的就是一张base64的图片
(6)演示
4、编译less
(1)项目文件

(2)main.js main.less代码如下
import './main.less'
main.js
@imgPath: './1.jpg';
body{
background-image:url(@imgPath);
}
main.less
(3)打包图片需要安装less-loader less,执行如下命令下载 因为less-loader是依赖于less的
npm install less-loader -D
npm install less -D
(4)此时package.json文件
{
"name": "css-loader1",
"version": "1.0.0",
"description": "",
"main": "main.js",
"scripts": {
"dev": "webpack --config ./webpack.dev.config.js",
"prod": "webpack --config ./webpack.prod.config.js"
},
"keywords": [],
"author": "",
"license": "ISC",
"devDependencies": {
"css-loader": "^2.1.1",
"file-loader": "^3.0.1",
"less": "^3.9.0",
"less-loader": "^4.1.0",
"style-loader": "^0.23.1",
"url-loader": "^1.1.2"
}
}
(4)在webpack.config文件夹中配置(注意你的路径)
var path = require('path')
// webpack ./main.js ./build.js
module.exports = {
// 入口
entry:{
// 可以有多个入口,也可以有一个,如果有一个就默认从这一个入口开始分析
"main":'./src/main.js'
},
output:{
//path:path.resolve('./dist'),//创建一个绝对路径,输入的时候输出一个dist文件
filename:'./src/build.js'
},
// 包含各个loader
module:{
loaders:[
{
test:/\.less$/,
loader:'style-loader!css-loader!less-loader'
}
]
},
watch:true//文件监视改动 自动产出build.js
// 声明模块
}
(5)完成
5、webpack将index.html 和build.js编译到同一个文件夹
当项目文件数目过多的时候,编译出来的build.js文件和index.html不是在同一个文件夹中,那么我们就需要手动改index.html中的引入路径
使用html-webpack-plugin插件可以在生成build.js的时候在同一文件夹下再生成一个index.html文件,
(1)下载
npm i html-webpack-plugin -D
(2)在congfig中配置
var path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin')
// webpack ./main.js ./build.js
module.exports = {
// 入口
entry:{
// 可以有多个入口,也可以有一个,如果有一个就默认从这一个入口开始分析
"main":'./main.js'
},
output:{
path:path.resolve('./dist'),
filename:'./build.js'
},
watch:true,//文件监视改动 自动产出build.js
// 声明模块
// 包含各个loader
module:{
loaders:[
{
// /遇到后缀为.css的文件,webpack先用css-loader加载器去解析这个文件
// 最后计算完的css,将会使用style-loader生成一个内容为最终解析完的css代码的style标签,放到head标签里。
// webpack在打包过程中,遇到后缀为css的文件,就会使用style-loader和css-loader去加载这个文件。
test:/\.css$/,
loader:'style-loader!css-loader'
},
{
test:/\.(jpg|png|jpeg|gif|svg)$/,
loader:'url-loader?limit = 3000'
}
]
},
plugins:[
new HtmlWebpackPlugin({
template:'./index.html' //这是是相对build.js的文件路径
})
]
}
三、总结
1、webpack.config文件配置:注意路径
2、webpack打包css文件:需要安装css-loader style-loader
3、webpack配置打包img文件: 需要安装 url-loader file-loader旭(图片大小小于你设置的大小的时候引入base64格式 , 反之额外生成一张图片)
4、编译less文件: 需要安装 less less-loader (less-loader是依赖于less)
5、webpack将index.html 和build.js编译到同一个文件夹: 需要安装
html-webpack-plugin
Vue(基础七)_webpack使用工具(下)的更多相关文章
- Vue(基础七)_webpack打包工具用法(上)
一.前言 1.webpack原理 二.主要内容 1.webpack原理: (1)官网图:我们的项目有多个js, css文件的时候还需要考虑先引入哪一个后引入哪一个,因为这些js文件是相互依赖的,web ...
- Vue(基础七)_webpack(CommonsChunkPlug的使用)
---恢复内容开始--- 一.前言 1.多入口文件配置 2.CommonsChunkPlugin的用法 ...
- Vue(基础七)_webpack(webpack异步加载原理)
---恢复内容开始--- 一.前言 1.webpack异步加载原理’ 2.webpack.ensure原理 ...
- Java基础七(Eclipse工具)
今日内容介绍1.Eclipse开发工具2.超市库存管理系统 ###01Eclipse的下载安装 * A: Eclipse的下载安装 * a: 下载 * http://www.eclipse.org ...
- Vue基础之内部指令(下)
v-on绑定事件监听器 直接撸代码: <div id="app"> <h2>计数器</h2> number:{{number}} <but ...
- vue基础七
事件处理器 1.监听事件 可以用 v-on 指令监听 DOM 事件来触发一些 JavaScript 代码. <div id="example-1"> <butto ...
- 从壹开始前后端分离 [ Vue2.0+.NET Core2.1] 十八║Vue基础: 指令(下)+计算属性+watch
回顾 今天来晚辣,给公司做了一个小项目,一个瀑布流+动态视频控制的DEMO,有需要的可以联系我,公司的项目就不对外展示了(一个后端程序员真的要干前端了哈哈哈). 书接上文,昨天正式的开始了Vue的代码 ...
- hadoop基础----hadoop实战(七)-----hadoop管理工具---使用Cloudera Manager安装Hadoop---Cloudera Manager和CDH5.8离线安装
hadoop基础----hadoop实战(六)-----hadoop管理工具---Cloudera Manager---CDH介绍 简介 我们在上篇文章中已经了解了CDH,为了后续的学习,我们本章就来 ...
- Bootstrap <基础七>按钮
任何带有 class .btn 的元素都会继承圆角灰色按钮的默认外观.但是 Bootstrap 提供了一些选项来定义按钮的样式,具体如下表所示: 以下样式可用于<a>, <butto ...
随机推荐
- oracle NVL与Coalesce的区别
先来说一下用法上的区别 : nvl(COMMISSION_PCT,0)如果第一个参数为null,则返回第二个参数如果第一个参数为非null,则返回第一个参数 COALESCE(EXPR1,EXPR2, ...
- hibernate一对多映射文件的配置
其中一个Customer对应多个LinkMan Customer的映射文件 Customer.hbm.xml-------------->一对多 <?xml version="1 ...
- 学习 Civil 3D二次开发从哪儿开始?
1.1 从哪儿开始 对于多数的工程设计人员,不完全具备上节所述的各种条件.对于Civil 3D的应用可能比较熟悉:但对于计算机语言,只限于上学时所学的一点基础知识,步入工作岗位后与计算机语言基本无缘: ...
- Deepfakes:AI换脸技术自制明星XX片
ps:亮瞎狗眼 去年开始就在国外网站上比较火的项目了,通过Deepfakes技术可以将视频中的人脸换成自己喜欢的明星, 当时就有不少人制作了换脸视频,其中大部分是替换了XX片的女主角. 国外网站Red ...
- codeforces1045B Space Isaac 【manacher】【差分】
题目大意: 题目是将$[0,m)$的数划成了两个集合,其中一个集合的元素个数不超过$n$.问在第一个集合中选出的数加上第二个集合中选出的数的和中没有出现的数有哪些. 题目分析: 很有意思的一道题.方便 ...
- UOJ274 [清华集训2016] 温暖会指引我们前行 【LCT】【最大生成树】
题目分析: 差评,最大生成树裸题.hack数据还卡常. 代码: #include<bits/stdc++.h> using namespace std; ; struct LCT{ ],d ...
- 洛谷P1209修理牛棚题解
题目 这个题一眼看上去是一个贪心,但是一个贪心题就一定要用一个贪心的做法来做吗,为什么不能写一个DP呢,这个题我们可以从他修理牛棚的角度来看,价值就是一个木板可以修几个,但是也同时消耗掉了一个木板的长 ...
- 【XSY1551】往事 广义后缀数组 线段树合并
题目大意 给你一颗trie树,令\(s_i\)为点\(i\)到根的路径上的字符组成的字符串.求\(max_{u\neq v}(LCP(s_u,s_v)+LCS(s_u,s_v))\) \(LCP=\) ...
- PhoneGap & Cordova 安装白皮书
1.前题: PhoneGap是一个用基于HTML,CSS和JavaScript的,创建移动跨平台移动应用程序的快速开发平台.它使开发者能够利用 iPhone,Android,Palm,Symbian, ...
- new 经典基础模板总结
NOIP-NOI-ZJOI基础模板总结 目录 C++语言和STL库操作 重载运算符操作 /* 重载运算符 格式 如重载小于号 这里是以x递减为第一关键字比较,y递减为第二关键字比较 */ bool o ...