文章说明,这篇主要是记录一下我学习的过程。以代码为主。一些概念啊,插件的用途说明啊不作任何说明。有任何不明白的请参照webpack中文官网https://doc.webpack-china.org/。这里以webpack版本为3.X为主。记住,版本很重要。javascript
webpack已升级到4版本,部分设置可能跟个人配置有些出入。可是原理方法是不变的。css
假如跟着作出现问题了:一、看看有没有提示语法错误,而且检查本身的代码有没有字母错漏的,初次接触容易出现这类问题 二、假如没有错误,换个端口号试试 三、去谷歌搜问题的缘由。html
全部的项目文件均可如下载。下载后运行npm i,而后再npm startjava
下载地址 连接:https://pan.baidu.com/s/1eYR75D8QEd6PleAeZQDWYQ 密码:kcy6node
1、初识webpack---打包工具。项目一react
一、建立文件,而后新建以下图1的文件,而后文件的内容按照个人截图进行输入代码。这里我新建了名为320webpack的项目webpack
---
es6
好了,而后就可使用命令了,进入320webpack的项目文件夹里,右键选择Git Base Here,敲打如下命令web
npm init -y //初始化项目,执行后会多一个package.json页面npm
//安装项目依赖,这里安装3.0版本的webpack,执行后会多了node_modules文件夹,里面放的都得项目的依赖插件
//若是直接输入npm i -D webpack ,最后会直接帮你安装最新的版本。
npm i -D webpack@3
npm i -D html-webpack-plugin //安装html-webpack-plugin插件,用来打包时建立html页面
而后进入package.json,
而后运行 npm run dev //这是一个运行打包的命令
打包成功后能够看到dist文件夹里面多了2个文件,而后用浏览器运行dist/index.html文件,能够看到输出了内容
一个简单的打包项目就完成了
2、loader--loader就是webpack用来预处理模块的,在一个模块被引入以前,会预先使用loader处理模块的内容
而后会用到一些react的东西。
项目仍是以前的项目,删掉a.js,b.js,c.js,而后按照截图修改文件内的代码
运行如下命令
npm i -S react react-dom //安装react所须要的模块
//浏览器只能跑js代码,而显然react的代码显然不是纯js代码,因此要使用babel-loader来帮助浏览器识别,而babel-loader依赖一个核心库babel-core
npm i -D babel-loader babel-core
npm i -D babel-preset-react //安装预设
npm run dev //运行,而后用浏览器运行dist/index.html文件
到这里就能够了,这里主要是要认识如下,loader--就是用来处理模块内容的
3、devserver ---- webpack的开发服务器,这是专门用来给咱们开发调试项目的,使用后能够直接在浏览器上运行咱们的项目
项目仍是以前的项目,而后按照截图修改文件内的代码
运行如下命令
//webpack-dev-server会将项目进行打包,打包以后并不会将资源放到本地的文件夹内,而是放到内存里面,当咱们访问那个地址时,就会从内存中提取资源
//安装devserver,这里由于webpack是3.x版本,因此这里安装webpack-dev-server的2.x版本。若是安装其余版本,运行汇报错。若是直接输入npm i -D webpack-dev-server,系统会自动安装最新的版本,
npm i -D webpack-dev-server@2
npm start ---就会开始运行
按ctrl + C就能够退出运行
运行后,咱们能够看到他的运行地址是localhost+自定义端口号。而且默认浏览器会自动运行这个地址,
4、引入css文件
项目仍是以前的项目,而后按照截图修改文件内的代码
运行如下命令
npm i -D css-loader //安装css-loader
npm i -D style-loader //安装style-loader ,这个的做用是把打包的样式插入到页面中
npm start //运行以后就看到以下效果了
5、引入图片
项目仍是以前的项目,而后按照截图新建文件及修改文件内的代码,自找几张图片,png,jpg,jpeg,gif的格式图片各一张,而且图片的内存大小不一
运行如下命令
npm i -D url-loader ////安装url-loader ,加强版的file-loader,用来处理文件的,好比图片,在打包的时候会从新命名文件的文件名
npm start //运行以后就看到以下效果了
npm run dev //打包
因为我只有一张图片是比较大的,因此我只有1张图片被打包了
6、引入字体
项目仍是以前的项目,而后按照截图新建文件及修改文件内的代码。去阿里巴巴矢量图标,下载几个图标,将下载下来的文件所有复制到fonts文件夹内,下载下来的文件有教你怎么使用这些字体图标的方法。直接复制过来。
运行如下命令
npm i -D file-loader //安装file-loader ,用来处理文件的,好比图片,在打包的时候会从新命名文件的文件名
npm start //运行以后就看到以下效果了
6、引入字体二,
假如你不须要自定义字体图标,直接使用font-awesome的字体图标的话,能够这么作。
项目仍是以前的项目,而后按照截图新建文件及修改文件内的代码。删掉fonts文件夹,运行
npm i -S font-awesome //下载font-awesome字体
下载后这个字体文件会被放在node_modules文件里面,能够在里面进行查看。下载font-awesome以后,当你要使用某个字体的时候,能够去它的官网http://fontawesome.dashgame.com/,找到对应的字体点进去,里面会有使用该字体的方法,复制过来就行了。
而后 npm strat 。效果以下显示
7、css模块化
项目仍是以前的项目,而后按照截图新建文件及修改文件内的代码。
而后就能够npm start 运行了。因为咱们会引入node_module里面的css文件,因此在配置文件里相应的作了些处理。配置文件进行文件匹配处理的顺序是从下往上,从右到左。
从输出的结果能够看出。在样式进行模块化以后,一、除了node_module里面的样式,其余全部的样式都要以对象接受的方式来引用。 二、对于与app.js同级的css文件,引入后,浏览器能接受到该文件的全部样式对象,并能够以对象的方式来使用样式 三、对于与app.js非同级的css文件。浏览器接收不到其样式对象。因此使用该文件的样式时,仍是以直接使用样式名的方式来使用才有效。
8、使用sass和less
项目仍是以前的项目,而后按照截图新建文件及修改文件内的代码。
而后执行如下命令
npm i -S sass-loader node-sass //下载sass-loader
npm i -S less-loader less //下载less-loader
npm start
9、优化babel-loader---主要是为了兼容es6的语法
项目仍是以前的项目,而后按照截图新建文件及修改文件内的代码。因为主要是babel,因此就先将以前的一些样式文件给删掉了。
而后执行如下命令
npm i -D babel-preset-env //安装babel-preset-env 预设es
npm i -D babel-plugin-transform-object-rest-spread
npm i -D babel-preset-es2015
npm start //结果以下,es6的语法也正常输出
10、再次优化babel-loader
项目仍是以前的项目,而后按照截图新建文件及修改文件内的代码。
而后npm start,效果也是同样的。
11、输出路径处理
项目仍是以前的项目,而后按照截图新建文件及修改文件内的代码。
const HtmlWebpackPlugin = require('html-webpack-plugin'); const path = require('path'); const CleanWebpackPlugin = require('clean-webpack-plugin'); module.exports = { entry: './src/app.js', output: { path: path.resolve(__dirname,'dist'), filename: 'js/app.js', //全部资源的基础路径,并且必定要以 "/"结尾 publicPath: '/' //会自动帮咱们应用上转化以后的路径 }, plugins: [ new HtmlWebpackPlugin({ filename: 'index.html', template: 'src/index.html' }), new CleanWebpackPlugin(['dist']) ], module: { rules: [ { test: /\.js$/, use: [{ loader: 'babel-loader' }], exclude: [ path.resolve(__dirname,'node_modules') ] }, { test: /\.css$/, use: [ 'style-loader', { loader: 'css-loader', options: { module: true, localIdentName: '[name]-[local]-[hash:base64:6]' } } ], exclude: [ path.resolve(__dirname,'node_modules'), path.resolve(__dirname,'src/common') ] }, { test: /\.css$/, use: ['style-loader','css-loader'], include: [ path.resolve(__dirname,'node_modules'), path.resolve(__dirname,'src/common') ] }, { test: /\.scss$/, use: [ 'style-loader', { loader: 'css-loader', options: { module: true, localIdentName: '[name]-[local]-[hash:base64:6]' } }, 'sass-loader' ], exclude: [ path.resolve(__dirname,'node_modules'), path.resolve(__dirname,'src/common') ] }, { test: /\.scss$/, use: ['style-loader','css-loader','sass-loader'], include: [ path.resolve(__dirname,'node_modules'), path.resolve(__dirname,'src/common') ] }, { test: /\.less$/, use: [ 'style-loader', { loader: 'css-loader', options: { module: true, localIdentName: '[name]-[local]-[hash:base64:6]' } }, 'less-loader' ], exclude: [ path.resolve(__dirname,'node_modules'), path.resolve(__dirname,'src/common') ] }, { test: /\.less$/, use: ['style-loader','css-loader','less-loader'], include: [ path.resolve(__dirname,'node_modules'), path.resolve(__dirname,'src/common') ] }, { test: /\.(jpeg|png|gif|jpg)$/, use: [{ loader: 'url-loader', options: { limit: 10000, name: 'img/[name]_[hash:8].[ext]' } }] }, { test: /\.(ttf|woff|svg|eot|woff2)$/, use: [{ loader: 'file-loader', options: { name: 'fonts/[name]_[hash:8].[ext]' } }] } ] }, devServer: { open: true, port: 9666, contentBase: './src/common', publicPath: '/' //指向资源被打包的地方 } }
npm i -D clean-webpack-plugin //安装清理插件
npm run dev //打包,打包后自动生成dist文件夹,而且将字体文件放到fonts文件,图片放到img文件夹,js放到js文件夹内。
npm start //正常输出了