一、前言

 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使用工具(下)的更多相关文章

  1. Vue(基础七)_webpack打包工具用法(上)

    一.前言 1.webpack原理 二.主要内容 1.webpack原理: (1)官网图:我们的项目有多个js, css文件的时候还需要考虑先引入哪一个后引入哪一个,因为这些js文件是相互依赖的,web ...

  2. Vue(基础七)_webpack(CommonsChunkPlug的使用)

    ---恢复内容开始--- 一.前言 1.多入口文件配置                               2.CommonsChunkPlugin的用法                   ...

  3. Vue(基础七)_webpack(webpack异步加载原理)

    ---恢复内容开始--- 一.前言 1.webpack异步加载原理’                                           2.webpack.ensure原理     ...

  4. Java基础七(Eclipse工具)

    今日内容介绍1.Eclipse开发工具2.超市库存管理系统 ###01Eclipse的下载安装 * A: Eclipse的下载安装  * a: 下载 * http://www.eclipse.org ...

  5. Vue基础之内部指令(下)

    v-on绑定事件监听器 直接撸代码: <div id="app"> <h2>计数器</h2> number:{{number}} <but ...

  6. vue基础七

    事件处理器 1.监听事件 可以用 v-on 指令监听 DOM 事件来触发一些 JavaScript 代码. <div id="example-1"> <butto ...

  7. 从壹开始前后端分离 [ Vue2.0+.NET Core2.1] 十八║Vue基础: 指令(下)+计算属性+watch

    回顾 今天来晚辣,给公司做了一个小项目,一个瀑布流+动态视频控制的DEMO,有需要的可以联系我,公司的项目就不对外展示了(一个后端程序员真的要干前端了哈哈哈). 书接上文,昨天正式的开始了Vue的代码 ...

  8. hadoop基础----hadoop实战(七)-----hadoop管理工具---使用Cloudera Manager安装Hadoop---Cloudera Manager和CDH5.8离线安装

    hadoop基础----hadoop实战(六)-----hadoop管理工具---Cloudera Manager---CDH介绍 简介 我们在上篇文章中已经了解了CDH,为了后续的学习,我们本章就来 ...

  9. Bootstrap <基础七>按钮

    任何带有 class .btn 的元素都会继承圆角灰色按钮的默认外观.但是 Bootstrap 提供了一些选项来定义按钮的样式,具体如下表所示: 以下样式可用于<a>, <butto ...

随机推荐

  1. 一、Dev

    一.获取选中的表格 // MessageBox.Show(gridview_Parent.GetFocusedDataRow()["series"].ToString());//获 ...

  2. A Simple Problem with Integers(线段树区间更新模板)

    最基本的线段树的区间更新及查询和 用tag(lazy)数组来“延缓”更新,查询或添加操作必须进行pushdown操作,即把tag从p传到lp和rp并清楚tag[p],既然得往lp和rp递归,那么就可以 ...

  3. CF980E

    题面 Panel 国将举办名为数字游戏的年度表演.每个省派出一名选手. 国家有 n 个编号从 1 到 n 的省,每个省刚好有一条路径将其与其他省相连.第 i 个省出来的代表有 2^i 名粉丝. 今年, ...

  4. P2123 皇后游戏

    题目背景 还记得 NOIP 2012 提高组 Day1 的国王游戏吗?时光飞逝,光阴荏苒,两年 过去了.国王游戏早已过时,如今已被皇后游戏取代,请你来解决类似于国王游 戏的另一个问题. 题目描述 皇后 ...

  5. Luogu5205 【模板】多项式开根(NTT+多项式求逆)

    https://www.cnblogs.com/HocRiser/p/8207295.html 安利! 写NTT把i<<=1写成了i<<=2,又调了一年.发现我的日常就是数组开 ...

  6. Codeforces986C AND Graph 【位运算】【dfs】

    题目大意: 一张$ m $个编号互异点图,最大不超过$ 2^n $,若两个编号位与为0则连边,问连通块数量. 题目分析: 考虑怎样的两个点会连边.这种说法对于A和B两个点来说,就相当于B在A的0的子集 ...

  7. 洛谷P1330封锁阳光大学题解

    题意 此题可以说是一个很裸的一个二分图染色,但是比较不同的是,这个图中可能是不联通的,因此我们需要找到所有的联通块,然后一一选出每个联通块中黑块与白块中最小的个数,然后加入到最后的答案中去,也是很坑的 ...

  8. 大学jsp实验5request,response

    1.request对象的使用 (1)编写一个包含有表单的JSP页面form.jsp,其中包含可以输入姓名和出生地的文本框,提交表单后在另一个页面中显示用户提交的姓名和出生地.请写出相应代码: form ...

  9. python列表解析式,字典解析式,集合解析式和生成器

    一.列表解析式(列表推倒式): 功能:是提供一种方便的列表创建方法,所以,列表解析式返回的是一个列表. 1 lst = [1, 3, 5, 8, 10] 2 ll = [x+x for x in ls ...

  10. POJ 3074 Sudoku(算竞进阶习题)

    二进制优化+dfs 话说这题数据中真的丧心病狂..不加inline还过不去.. 因为不会DLX只好用二进制来优化了...万万没想到还是低空飘过 我们在行.列.格分别用一个9位二进制常数来记录什么数能放 ...