关于Webpack前两篇跟大家分享的主要是Webpack的一些基本的配置,今天开始我们详细了解一下有关Webpack的各种配置,今天主要跟大家分享的是Webpack的资源入口和资源出口的配置。

如果想了解前两篇的文章请访问下面的地址:

Webpack实战(一):Webpack打包工具安装及参数配置

Webpack实战(二):webpack-dev-server的介绍与用法

资源入口配置

资源入口配置是Webpack配置中不可缺少的一个环节,Webpack通过context和entry这两个配置项来共同决定入口文件的路径。从英文翻译过来的字面的意思可以了解到context是上下文的意思,entry是入口,在配置入口的时候其实做了两件事情:

  • 确定入口模块位置,告诉Webpack从哪里开始进行打包。
  • 定义chunk name。如果工程只有一个入口,那么默认其chunk name为“main”;如果工程有多个入口,我们需要为每个入口定义chunk name,来作为该chunk的唯一标识。

context可以理解为资源入口的路径前缀,在配置时要求必须使用绝对路径的形式,配置代码例子如下:

const path = require('path')
module.exports = {
context: path.join(__dirname, './src')
entry: './index.js',
output: {
path: path.join(__dirname, 'dist'),
filename: 'bundle.js'
},
mode: 'development',
"devServer": {
"publicPath": './dist',
"port": 3000
}
}

其实context 的配置相当于引入前缀‘src’,如果不用context,可以配置成

entry: './src/index.js'

context这个配置可以省略,配置context的主要目的是让entry的编写更加简洁,尤其是在多入口的情况下。

entry的配置可以有多种形式:字符串、数组、对象、函数。可以根据不同的需求场景来选择。

  1. 字符串类型入口

    直接传入路径入口,如下
module.exports = {
entry: './src/index.js',
output: {
filename: 'bundle.js'
},
mode: 'development',
"devServer": {
"publicPath": './dist',
"port": 3000
}
}
  1. 数组类型入口

    传入一个数组的作用是将多个资源预先合并,在打包时Webpack会将数组中的最后一个元素作为实际的入口路径。如:

module.exports = {
entry: ['./add.js', './index.js'],
output: {
filename: 'bundle.js'
}
}

其实这种做法相当于字符串引入的一种,就如

module.exports = {
entry: './src/index.js',
output: {
filename: 'bundle.js'
}
}
// index.js 文件引入add文件
import './add'

数组类型入口其实数组里的js文件最后还是合并到一个文件bundle.js上

  1. 对象类型入口

    如果想要定义多入口,则必须使用对象的形式。对象的属性名(key)是chunk name,属性值(value)是入口路径。如
module.exports = {
entry: {
index: './src/index.js', // chunk name 为 index
add: './src/add.js' // chunk name 为 add
},
output: {
filename: 'bundle.js'
}
}

注意:对象的属性值也可以为字符串或数组。

module.exports = {
entry: {
index: ['./add2.js', './index.js'] // chunk name 为 index
add: './src/add.js' // chunk name 为 add
},
output: {
filename: 'bundle.js'
}
}
  1. 函数类型入口

用函数定义入口时,只要返回上面介绍的任何配置形式即可,如:

// 返回字符串形式的入口
module.exports = {
entry: () => './src/index.js',
output: {
filename: 'bundle.js'
}
} // 返回对象形式的入口
module.exports = {
entry: () => ({
index: ['./add2.js', './index.js'] // chunk name 为 index
add: './src/add.js' // chunk name 为 add
}),
output: {
filename: 'bundle.js'
}
}

用函数作为一个入口的好处是我们可以在函数体里添加一些动态的逻辑来获取项目的入口,另外,函数也支持返回一个Promise对象来进行异步操作。例子如下:

module.exports = {
entry: () => new Promise((resolve) => {
// 模拟异步操作
setTimeout(()=> {
resolve('./src/index.js')
}, 1000)
}),
output: {
filename: 'bundle.js'
}
}

资源出口配置

接下来,让我们详细去了解一下资源出口的配置,资源出口配置的参数大部分都在output里面,这里先了解一下几个常用的配置参数。

  1. filename

    filename是控制输出资源的文件名,是字符串形式

    如:
const path = require('path')
module.exports = {
context: path.join(__dirname, './src'),
entry: './index.js',
output: {
path: path.join(__dirname, 'dist'),
filename: 'bundle.js'
},
mode: 'development',
"devServer": {
"publicPath": './dist',
"port": 3000
}
}

打包效果如下



filename不仅可以是文件名,也可以是路径,如下:

const path = require('path')
module.exports = {
context: path.join(__dirname, './src'),
entry: './index.js',
output: {
filename: './dist/bundle.js'
},
mode: 'development'
}



在多入口的场景中,如果需要为对应产生的每个bundle指定不同的名字,Webpack支持使用一种类似模板语言的形式动态地生成文件名,如:

const path = require('path')
module.exports = {
context: path.join(__dirname, './src'),
entry: {
index: './index.js', //chunk name 为index
index2: './index2.js' //chunk name 为index2
},
output: {
filename: '[name].js'
},
mode: 'development'
}

在资源输出时,上面配置的filename中的[name]会被替换为chunk name,因此最后项目中实际生成的资源是index.js与index2.js

在我们做实际项目中,使用比较多的是[name],它与chunk是一一对应的关系,并且可读性较高。如果要控制客户端缓存,最好还要加上[chunkhash],因为每个chunk所产生的[chunkhash]只与自身内容有关,单个chunk内容的改变不会影响其他资源,可以最精确地让客户端缓存得到更新。

如下:

const path = require('path')
module.exports = {
context: path.join(__dirname, './src'),
entry: {
index: './index.js',
index2: './index2.js'
},
output: {
filename: '[name]@[chunkhash].js'
},
mode: 'development'
}

打包的效果如下:



这个[chunkhash] 更新缓存配置一般只在生产环境中配置,不在开发环境中配置

  1. path参数

    path可以指定资源输出的位置,要求值必须为绝对路径。如:
const path = require('path')
module.exports = {
context: path.join(__dirname, './src'),
entry: {
index: './index.js',
index2: './index2.js'
},
output: {
path: path.join(__dirname, 'dist')
filename: '[name]@[chunkhash].js'
},
mode: 'development'
}

在Webpack 4之后,output.path已经默认为dist目录,除非我们需要更改它,否则不必单独配置。

  • publicPath
module.exports = {
entry: './src/index.js',
output: {
filename: 'bundle.js'
},
mode: 'development',
"devServer": {
"publicPath": './dist',
"port": 3000
}
}

publicPath跟path有很大的区别:path用来指定资源的输出位置,而publicPath则用来指定资源的请求位置的。

  • 输出位置:打包完成后资源产生的目录,一般将其指定为项目中的dist目录。
  • 请求位置:由JS或CSS所请求的间接资源路径。页面中的资源分为两种,一种是由HTML页面直接请求的,比如通过script标签加载的JS;另一种是由JS或CSS请求的,如异步加载的JS、从CSS请求的图片字体等。publicPath的作用就是指定这部分间接资源的请求位置。

webpack-dev-server的配置中也有一个publicPath,但是,这个publicPath与Webpack中的配置项含义不同,它的作用是指定webpack-dev-server的静态资源服务路径。详情请查看《Webpack实战(二):webpack-dev-server的介绍与用法

为了避免开发环境和生产环境产生不一致而造成开发者的疑惑,我们可以将webpack-dev-server的publicPath与Webpack中的output.path保持一致,这样在任何环境下资源输出的目录都是相同的

总结

有关Webpack资源入口和资源出口的配置就暂时分析到这里,这仅代表个人观点,欢迎拍砖,如想了解更多请扫描下面:

Webpack实战(三):作为前端你不得不懂的Webpack资源入口和出口的配置的更多相关文章

  1. Webpack实战(五):轻松读懂Webpack如何分离样式文件

    在上一篇文章中我给大家分享了预处理器(loader),里面讲到了style-loader 和css-loader,有关样式引入的问题,但是上面的样式文件只是引入到style标签里面,并不是我想要的样式 ...

  2. Webpack实战(四):教教你如何轻松搞定-预处理器(loader)

    前面三节,我主要给大家分享了有关webpack的一些配置的知识点,如何打包js文件,而如果我们遇到其他类型的资源如图片.css.字体font等等,我们该如何处理呢?今天会介绍预处理器(loader), ...

  3. 30分钟手把手教你学webpack实战

    30分钟手把手教你学webpack实战 阅读目录 一:什么是webpack? 他有什么优点? 二:如何安装和配置 三:理解webpack加载器 四:理解less-loader加载器的使用 五:理解ba ...

  4. webpack实战

    webpack实战 30分钟手把手教你学webpack实战 2015-09-08 23:02 by 龙恩0707, 175 阅读, 0 评论, 收藏, 编辑 30分钟手把手教你学webpack实战 阅 ...

  5. 每天记录一点:NetCore获得配置文件 appsettings.json vue-router页面传值及接收值 详解webpack + vue + node 打造单页面(入门篇) 30分钟手把手教你学webpack实战 vue.js+webpack模块管理及组件开发

    每天记录一点:NetCore获得配置文件 appsettings.json   用NetCore做项目如果用EF  ORM在网上有很多的配置连接字符串,读取以及使用方法 由于很多朋友用的其他ORM如S ...

  6. 前端工程化(二)---webpack配置

    导航 前端工程化(一)---工程基础目录搭建 前端工程化(二)---webpack配置 前端工程化(三)---Vue的开发模式 前端工程化(四)---helloWord 继续上一遍的配置,本节主要记录 ...

  7. .NET-记一次架构优化实战与方案-前端优化

    目录 .NET-记一次架构优化实战与方案-梳理篇 .NET-记一次架构优化实战与方案-前端优化 .NET-记一次架构优化实战与方案-底层服务优化 前言 上一篇<.NET-记一次架构优化实战与方案 ...

  8. 使用webpack+vue.js构建前端工程化

    参考文章:https://blog.csdn.net/qq_40208605/article/details/80661572 使用webpack+vue.js构建前端工程化本篇主要介绍三块知识点: ...

  9. 30分钟学webpack实战

    阅读目录 一:什么是webpack? 他有什么优点? 二:如何安装和配置 三:理解webpack加载器 四:理解less-loader加载器的使用 五:理解babel-loader加载器的含义 六:了 ...

随机推荐

  1. jmeter登录配置

    前言: jmeter, Apache下的测试工具, 常用来进行压测, 项目中, 接口通常都需要进行登录才能被调用, 直接调用将提示"登录失效", 下面介绍如何在jmeter中配置参 ...

  2. 2018-8-10-win10-uwp-绘图--Line-控件使用

    title author date CreateTime categories win10 uwp 绘图 Line 控件使用 lindexi 2018-08-10 19:16:51 +0800 201 ...

  3. linux版本依赖

    记住, 你的模块代码一定要为每个它要连接的内核版本重新编译 -- 至少, 在缺乏 modversions 时, 这里不涉及因为它们更多的是给内核发布制作者, 而不是开发者. 模块 是紧密结合到一个特殊 ...

  4. 【codeforces 749A】Bachgold Problem

    time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...

  5. vue在html中写动态背景图片

    <div class="img" :style="`background: url(`+item.img+'?any_string_is_ok'+`)center ...

  6. [HNOI2019]白兔之舞

    memset0 多合一无聊题 mod k=t,并且k是p-1的约数 单位根反演石锤了. 所以直接设f[i]表示走i步的方案数, 然后C(L,i)分配位置,再A^i进行矩乘得到f[i] 变成生成函数F( ...

  7. 【2016常州一中夏令营Day3】

    小 W 摆石子[问题描述]小 W 得到了一堆石子,要放在 N 条水平线与 M 条竖直线构成的网格的交点上.因为小 M 最喜欢矩形了,小 W 希望知道用 K 个石子最多能找到多少四边平行于坐标轴的长方形 ...

  8. hibernate_检索策略

    一.概述 检索策略分三大块,类级别检索策略和关联级别检测策略. 类级别检索策略:get.load. 关联级别检索策略:order.getCustomer().getName() 上面这两种应该是看得懂 ...

  9. 适配器模式 iOS

    前言: 最近需求作一个公共空间的需求,最后决定用适配器模式来做. 首先,需求是什么? 在我们app中,会有很多列表,tableviewcell的样式会比较统一(当然,我之前在公司那个app不算很大,基 ...

  10. ajax异步发送时遇到的问题

    问题原因是:controller中方法名与url中的名字不一样造成的 解决办法:找到错误的方法名,将其与url中的方法名统一: