webpack 1.x
http://webpack.github.io/docs/
—->
webpack 2.x
https://doc.webpack-china.org/concepts/
1.x和2.x区别:
2.x版本多了一些plugin,loader —->举例
webpack配置的写法上有更新,比如loaders的写法.
从1.x版本到2.x版本的webpack配置文件的更新:
https://doc.webpack-china.org/guides/migrating/
entry
output
plugin
loaders(webpack 2.x,把module.loaders,改为module.rules)
需要下载webpack
下载方式:
npm install webpack -g 全局,会生成package.json
npm install webpack –save-dev 会加到本项目开发中参数
安装的时候可以用cnpm,也可以直接用nrm切换安装源。但是要先安装nrm
npm config list
npm install -g nrm
nrm ls
nrm use taobao
npm config list
查看npm配置就可以看到现在用的是哪个
简单demo从hello world开始:
1.新建webpack.config.js的webpack的配置文件
2.新建index.html。新建index.js,并在webpack.config.js中把entry配置为index.js(index.ts同理)
3.index.js中引入依赖,写上要执行的方法
4.编译命令 webpack –config webpack.config.js
也可直接使用”webpack”命令。
webpack 提供了 Node.js API,可以在 Node.js 运行时下直接使用。
demo核心代码:
const path = require('path');
var webpack = require("webpack");
const config = {
entry: {
main: './src/index.js'
},
output: {
filename: '[name]-[hash:8].js',
path: path.join(__dirname, 'dist'),
},
module: {
rules: [
{
test: /\.html/, use: ['html-loader']
}
]
},
plugins: [
new HtmlWebpackPlugin({
filename: 'index.html',
template: __dirname + '/index.html'
})
]
}
module.exports = config;
var express = require(‘express’);//启动node服务
var app = express();
app.use(‘/hello’, function(req, res, next){
res.send(“hello”);
})
app.listen(3000, function(){
});
启动命令:node server.js
npm install –global gulp
npm install –save-dev gulp
全局安装了gulp,项目也安装了gulp。全局安装gulp是为了执行gulp任务,本地安装gulp则是为了调用gulp插件的功能。
npm init //可以自动生成package.json
配置hello任务gulp.task
gulp hello 运行hello任务
npm install gulp-sass –save-dev 安装gulp-sass插件
配置sass任务
gulp sass 运行sass任务
demo代码:
var gulp = require('gulp');
var sass = require('gulp-sass');
gulp.task('hello', function() {
// 将你的默认的任务代码放在这
console.log('hello world!');
});
gulp.task('sass',function(){
return gulp.src('src/main/webapp/static/styles/scss/apply.scss')
.pipe(sass())
.pipe(gulp.dest('src/main/webapp/static/styles/css'))
});
Gulp侧重于前端开发的 整个过程 的控制管理(像是流水线),我们可以通过给gulp配置不通的task(通过Gulp中的gulp.task()方法配置,比如启动server、sass/less预编译、文件的合并压缩等等)来让gulp实现不同的功能,从而构建整个前端开发流程。
Webpack有人也称之为 模块打包机 ,由此也可以看出Webpack更侧重于模块打包,当然我们可以把开发中的所有资源(图片、js文件、css文件等)都可以看成模块,最初Webpack本身就是为前端JS代码打包而设计的,后来被扩展到其他资源的打包处理。Webpack是通过loader(加载器)和plugins(插件)对资源进行处理的。
另外我们知道Gulp是对整个过程进行控制,所以在其配置文件(gulpfile.js)中配置的每一个task对项目中 该task配置路径下所有的资源 都可以管理。比如,对sass文件进行预编译的task可以对其配置路径下的所有sass文件进行预编译处理:
gulp.task('sass',function(){
gulp.src('src/styles/*.scss')
.pipe(sass().on('error',sass.logError))
.pipe(gulp.dest('./build/prd/styles/'));//编译后的输出路径
});
上面这个task可以对 ‘src/styles/*.scss’ 目录下的所有以 .scss 结尾的文件进行预处理。
4.Webpack则不是这样管理资源的,它是根据模块的 依赖关系 进行静态分析,然后将这些模块按照指定的规则生成对应的静态资源.
通俗的说,Webpack就是需要通过其配置文件(webpack.config.js)中 entry 配置的一个入口文件(JS文件),如下图
entry: {
app: __dirname + “/src/scripts/app.js”,
}
然后Webpack进入该 app.js 文件进行解析.
解析过程中,发现一个 app.scss 文件,然后根据 webpack.config.js 配置文件中的 module.loaders 属性去查找处理 .scss 文件的loader进行处理,处理 app.scss 文件过程中,如果发现该文件还有其他依赖文件,则继续处理 app.scss 文件的依赖文件,直至处理完成该“链路”上的依赖文件,然后又遇到一个 Greeter.js 模块,于是像之前一样继续去查找对应的loader去处理…
所以,Webpack中对资源文件的处理是通过入口文件产生的依赖形成的,不会像Gulp那样,配置好路径后,该路径下所有规定的文件都会受影响。
5.备注:Gulp对js文件的模块化工作是通过Webpack实现的,具体来说是通过安装 gulp-webpack 模块和相关的 loader 模块进行js模块化管理的。