webpck4.x系列-output

栏目: 编程语言 · 发布时间: 5年前

内容简介:说过了entry,与之相对应的便是output目录

说过了entry,

与之相对应的便是output

output出口

目录

配置 output 选项可以控制 webpack 如何向硬盘写入编译文件。注意,即使可以存在多个入口起点,但只指定一个输出配置。

output的配置项要比entry多

具体详细的配置,可以 参考

filename

打包输出的文件名,默认值为main.js

webpack.config.js

const path =require('path')
module.exports = {
  context: path.resolve(__dirname, "src"),
  entry: "./index.js",
  output: {
    filename: "[name].js"
  }
};

[name],是占位符,入口名是什么,[name]就是什么

entry名称的缺省值是main,则name的值就是main

如果entry使用数组,名称被缺省,output自然也是main

当然以不使用占位符

output: {
    filename: "bundle.js"
  }

那么dist下就会生成bundle.js

filename的配置支持多种占位符

[hash]

[chunkhash]

[contenthash]

[id]

[name]

[query]

[function]

我们先看下这个三个hash的区别

hash

output: {
    filename: "bundle.[hash].js"
  }

hash是项目级别的,什么意思?

即每次修改任何一个文件,所有文件名的hash至都将改变。所以一旦修改了任何一个文件,整个项目的文件缓存都将失效。所以对于没有改变的模块而言,这样做显然不恰当,因为缓存失效了。此时,chunkhash的用途随之而来。

chunkhash

output: {
    filename: "bundle.[chunkhash].js"
  }

只有被修改了的文件的文件,chunkhash值才会修改

contenthash

当使用ExtractTextWebpackPlugin这个插件时,

这个插件时用来分离css的,在使用时hash

和chunkhash不会起作用,此时要使用contenthash

hash(chunkhash,contenthash)的长度可以使用 [hash:16](默认为20)来指定。或者,通过指定output.hashDigestLength 在全局配置长度。

[id]

id是唯一标示,不会重复,从0开始

[name]

name 是模块名称,是你自己起的,在配置路由懒加载的时候可以自己命名

[function]

function,做动态配置的时候会用到。

例如根据不同的环境会有不同的输出

const path =require('path')
function filenameFun(){
//....一些判断逻辑,不同的环境不同配置
  return "bundle.[hash:8].js"
}
module.exports = {
  context: path.resolve(__dirname, "src"),
  entry: "./index.js",
  output: {
    filename: filenameFun
  }
};

[query]

模块的 query,例如,文件名 ? 后面的字符串

没用过,使用方法和场景,官网也没有做详细介绍

先打断一下

我们现在要对package.json,做一下修改

"scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "build:dev": "cross-env NODE_ENV=development webpack --config webpack.config.js --progress ",
    "build:prod": "cross-env NODE_ENV=production webpack --config webpack.config.js --progress "
  },

cross-env是用来兼容各个平台而使用的

以上配置是用来区分打包环境

现在继续filename

修改webpack.config.js

const path =require('path')
function filenameFun(){
  if( process.env.NODE_ENV === "development"){
    return "static/js/bundle.js"
  }else{
    return "static/js/bundle.[chunkhash].js"
  }

}
module.exports = {
  context: path.resolve(__dirname, "src"),
  entry: "./index.js",
  output: {
    filename: filenameFun
  }
};

我们修改了filename的输出路径

"static/js/bundle.js"

删除dist,执行npm run build:dev

打包成功后,dist目录下会生成一个static目录,static目录下有个js文件夹,然后是bundle.js文件

filename支持指定路径输出

chunkFilename

此选项决定了非入口 chunk 文件的名称,

什么场景需要呢?

模块异步加载,路由懒加载,这样的文件是没有被列在entry中的

path

path是配置输出文件存放在本地的目录,字符串类型,是绝对路径

const path =require('path')

module.exports = {
  context: path.resolve(__dirname, "src"),
  entry: "./index.js",
  output: {
    path: path.resolve(__dirname, 'dist/static'),
    filename: "js/bundle.js"
  },
};

效果相同

publicPath

静态资源远程地址(CDN)

默认值是一个空串

在多数情况下,此选项的值都会以/结束。

总结

本文介绍了一些关于output的常用api

* filename,输出的文件名,支持多种占位符,支持配置路径

* 介绍了三种hash(hash,chunkhash,contenthash)的区别

* chunkFilename,非入口 chunk 文件的名称,配置懒加载和异步模块的文件名

* path,是配置输出文件存放在本地的目录,字符串类型,是绝对路径

* publicPath 静态资源的远程地址,在配置CDN时会用到


以上所述就是小编给大家介绍的《webpck4.x系列-output》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Introduction to Semi-Supervised Learning

Introduction to Semi-Supervised Learning

Xiaojin Zhu、Andrew B. Goldberg / Morgan and Claypool Publishers / 2009-6-29 / USD 40.00

Semi-supervised learning is a learning paradigm concerned with the study of how computers and natural systems such as humans learn in the presence of both labeled and unlabeled data. Traditionally, le......一起来看看 《Introduction to Semi-Supervised Learning》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具