本文作者:IMWeb 黎清龙 原文出处:IMWeb社区 未经同意,禁止转载
打包,本质来说就是把许多零散的文件有序的合并成为一个文件,达到前端优化的效果
它的前世今生就不说了,感兴趣的同学可以去学习相关知识
构建 != 打包,反之亦然 打包可以说是构建的一环,构建可以做更多的事情 但是,打包永远都是构建的一个核心
打包工具有很多,下面稍微介绍一下笔者认识的:
准确来说,grunt 是个构建工具
它只是提供了一些基础能力,出现的较早,社区强大
gulp 和 grunt 很像,就不多聊了
可以说,fis 比较大,对整个打包过程有一个核心规范和流程,并且总结并提供了打包构建中的3个核心能力
fis 是一个很值得去学习的构建框架
这个应该是目前最受欢迎与关注的工具了
就个人学习而言,相比其他工具,webpack 是一个专注于打包的工具,因为专注,所以强大
打包过程实际上很简单,也非常直观,其逻辑如下图所示:
webpack 的基本使用就不介绍了,看一下文档就知道了
实际上 webpack 的核心是依赖分析,把依赖分析出来了,其他都是细枝末节了
比如 支持什么模块化规范,比如插件等等
使用 webpack 主要是看怎么 config 下面看看 webpack 官方文档的目录:
看到 config 目录那么多,就说明 webpack 的功能有多大
那么多内容可能无从下手,但是大多数情况下只需要关注核心的一些配置即可
下面主要讲解上图的红框部分
这个就是【入口文件】配置,通过这个 option 来确定入口文件,它有3种格式:
string 和 array 最终会打包成一个文件,object 则可以打包出多个文件
配置【出口文件】
它主要做两种事情:
看下面的例子:
// js/a.js
require('./c.js');
var a = 1;
// js/b.js
require('./c.js');
var b = 1;
// js/c.js
var c = 1;
// webpack.config.js
module.exports = {
entry: {
a: './js/a.js',
b: './js/b.js'
},
output: {
path: __dirname + '/dist',
filename: "[name].js"
}
};
上面就是输出多文件的配置
如果是要打包库文件,则需要用常规的模块包裹头,webpack 也能轻松支持:
module.exports = {
entry: {
a: './js/a.js'
},
output: {
path: __dirname + '/dist',
filename: "L.js",
library: 'L',
libraryTarget: 'umd'
}
};
输出的L文件就有了常规模块化包裹头:
(function webpackUniversalModuleDefinition(root, factory) {
if(typeof exports === 'object' && typeof module === 'object')
module.exports = factory();
else if(typeof define === 'function' && define.amd)
define([], factory);
else if(typeof exports === 'object')
exports["L"] = factory();
else
root["L"] = factory();
})(this, function() {
return /******/ (function(modules) { // webpackBootstrap
// ...
resolve 主要是分析依赖时的路径识别的配置
上面的例子中:a.js 和 b.js 文件都是在js文件夹里面的,然后 require 的时候要用相对路径
通过 resolve 可以帮助我们可以书写更加简单方便的依赖路径,比如:
// main.js
require('a');
var main = 1;
// webpack.config.js
var path = require('path');
module.exports = {
entry: {
b: './js/b.js',
c: './main.js'
},
output: {
path: __dirname + '/dist',
filename: "[name].js",
},
resolve: {
root: [
path.resolve('./js/')
]
}
};
如果没有 resolve.root 的配置,则需要写成:require('./js/a')
externals 是配置外部依赖的,如果使用某些第三方库的时候,就可以通过这个配置来识别外部第三方库的依赖 比如:
module.exports = {
entry: './main.js',
output: {
filename: 'L.js',
library: 'L',
libraryTarget: 'umd'
},
externals: {
'jquery': {
root: 'jquery',
amd: 'jquery',
commonjs2: 'jquery',
commonjs: 'jquery'
}
}
};
这个配置显示将要打包的库文件要依赖 jquery 库,打包之后的文件如下:
(function webpackUniversalModuleDefinition(root, factory) {
if(typeof exports === 'object' && typeof module === 'object')
module.exports = factory(require("jquery"));
else if(typeof define === 'function' && define.amd)
define(["jquery"], factory);
else if(typeof exports === 'object')
exports["Q"] = factory(require("jquery"));
else
root["Q"] = factory(root["jQuery"]);
})(this, function(__WEBPACK_EXTERNAL_MODULE_4__) {
return /******/ (function(modules) { // webpackBootstrap
对于一个工具来说,watch 功能是非常重要的
对于一个成熟的框架,插件化是扩展性的一个重要的功能点,感兴趣的同学可以深入学习
webpack 是一个专注于打包的工具,它使用简单,功能强大
而且可以作为一个构建框架的打包核心插件,比如grunt,gulp
本文仅仅介绍了webpack的一些核心属性,不多,但是已经可以满足绝对部分需求