前端工程化之:webpack1-11(其他配置)

目录

一、context

二、output

1.library

2.libraryTarget

三、target

四、module.noParse

五、resolve

1.modules

2.extensions

3.alias

六、externals

七、stats


一、context

javascript 复制代码
context: path.resolve(__dirname, "app")

该配置会影响入口和 loaders 的解析,入口和 loaders 的相对路径会以 context 的配置作为基准路径,这样,你的配置会独立于 CWD (current working directory 当前执行路径)。

javascript 复制代码
var path = require("path");
module.exports = {
    mode: "development",
    devtool: "source-map",
    entry: {
        index: "./index.js", // 利用context相当于是"./src/index.js"
        a: "./a.js"
    },
    context: path.resolve(_dirname,"src")
}

二、output

1.library

javascript 复制代码
library: "abc"

这样一来,打包后的结果中,会将自执行函数的执行结果暴露给 abc ,类似 jq 一样供外部调用的接口。

src/index.js :

javascript 复制代码
module.exports = function print(){
	console.log("print");
}

dist/main.js :

javascript 复制代码
var abc = (function (module){})({"./src/index.js": ...})

2.libraryTarget

javascript 复制代码
libraryTarget: "var"

该配置可以更加精细的控制如何暴露入口包的导出结果。

其他可用的值有:

三、target

javascript 复制代码
target:"web" //默认值
javascript 复制代码
module.exports = {
    mode: "development",
    devtool: "source-map",
    entry: {
        index: "./index.js", // 利用context相当于是"./src/index.js"
    },
    context: path.resolve(_dirname,"src"),
    target:"node" //打包后的代码运行在node环境中
}

设置打包结果最终要运行的环境,常用值有:

四、module.noParse

javascript 复制代码
noParse: /jquery/ // 不再分析依赖、抽象语法树
noParse: /a\.js$/ //不对a模块做任何操作,直接将其源代码放置到模块内容中

不解析正则表达式匹配的模块,通常用它来忽略那些大型的单模块库,以提高构建性能。

五、resolve

resolve 的相关配置主要用于控制模块解析过程。

1.modules

javascript 复制代码
modules: ["node_modules"]  //模块的查找位置,默认值,可以多个值

当解析模块时,如果遇到导入语句, require("test") (没有指定具体路径), webpack 会从下面的位置寻找依赖的模块:

  1. 当前目录下的 node_modules 目录
  2. 上级目录下的 node_modules 目录
  3. ...

对于 require(...) 是在 webpack 环境中去寻找该包,且不管在什么代码中,出现 require 就会寻找并解析成语法树。

2.extensions

javascript 复制代码
extensions: [".js", ".json"]  //默认值

当解析模块时,遇到无具体后缀的导入语句,例如 require("test") ,会依次测试它的后缀名:

  • test.js
  • test.json

webpack 会根据 extensions 的配置自动补全后缀名。

3.alias

javascript 复制代码
alias: {
  "@": path.resolve(__dirname, 'src'),
  "_": __dirname
}

src/index.js :

javascript 复制代码
require('./src/a/b/c/d.js');
//require('@/d.js');

有了 alias(别名)后,导入语句中可以加入配置的键名,例如 require("@/abc.js") , webpack 会将其看作是 require (src的绝对路径+"@/abc.js")。

在大型系统中,源码结构往往比较深和复杂,别名配置可以让我们更加方便的导入依赖

六、externals

javascript 复制代码
externals: {
    jquery: "$",
    lodash: "_"
}

从最终的 bundle 中排除掉配置的配置的源码,例如,入口模块是:

index.js :

javascript 复制代码
require("jquery")
require("lodash")

生成的 bundle 是:

javascript 复制代码
(function(){
    ...
})({
    "./src/index.js": function(module, exports, __webpack_require__){
        __webpack_require__("jquery")
        __webpack_require__("lodash")
    },
    "jquery": function(module, exports){
        //jquery的大量源码
    },
    "lodash": function(module, exports){
        //lodash的大量源码
    },
})

但有了上面的配置后,则变成了:

javascript 复制代码
(function(){
    ...
})({
    "./src/index.js": function(module, exports, __webpack_require__){
        __webpack_require__("jquery")
        __webpack_require__("lodash")
    },
    "jquery": function(module, exports){
        module.exports = $;
    },
    "lodash": function(module, exports){
        module.exports = _;
    },
})

这比较适用于一些第三方库来自于外部CDN的情况,这样一来,即可以在页面中使用 CDN ,又让 bundle 的体积变得更小,还不影响源码的编写。

七、stats

stats 控制的是构建过程中控制台的输出内容。

相关推荐
2501_920931705 小时前
React Native鸿蒙跨平台采用ScrollView的horizontal属性实现横向滚动实现特色游戏轮播和分类导航
javascript·react native·react.js·游戏·ecmascript·harmonyos
0思必得07 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东5167 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino7 小时前
图片、文件的预览
前端·javascript
2501_920931709 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
layman05289 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔9 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李9 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN9 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒9 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局