| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> JavaScript知识库 -> Webpack--资源输入输出 -> 正文阅读 |
|
[JavaScript知识库]Webpack--资源输入输出 |
一、资源处理流程(1)指定一个或多个入口(entry),也就是告诉webpack具体从源码目录下的哪个文件开始打包。 (2)存在依赖关系的模块会在打包时被封装为一个chunk(代码块,在webpack中可以被理解成被抽象和包装过后的一些模块) (3)根据具体配置不同,一个工程打包时可能会产生一个或多个chunk。 (4)webpack会从入口文件开始检索,并将具有依赖关系的模块生成一颗依赖树,最终得到一个chunk。由整个chunk得到的打包产物我们一般称之为bundle。 (5)每一个入口都会产生一个结果资源。(entry和bundle存在着对应关系)(存在特殊情况) (6)在webpack默认配置中,当一个bundle大于250KB时(压缩前)会认为这个bundle已经过大了,在打包时会发生警告。 二、配置资源入口Webpack通过context和entry这两个配置项来共同决定入口文件的路径。在配置入口时,实际上做了两件事:
?
context可以理解为资源入口的路径前缀,在配置时要求必须使用绝对路径的形式。?(只能为字符串)
(1)字符串类型 (2)数组类型入口 作用:将多个资源预先合并,在打包时webpack会将数组中最后一个元素作为实际的入口路径
(3)对象类型入口 定义多入口,必须使用对象的形式。对象的属性名(key)是chunk name,属性值(value)是入口路径(可以为字符串或数组)。
?(4)函数类型入口 1、用函数类型定义入口时,只要返回上面介绍的任何配置形式即可。 2、优点:可以在函数体内添加一些动态的逻辑来获取工程的入口。 3、支持返回一个promise对象来进行异步操作。
?(1)vendor的意思是“供应商”,在webpack中vendor一般指的是工程所使用的库,框架等第三方集中打包而产生的bundle。 ?(2)使用CommonsChunkPlugins(webpack4后为optimaization.splitChunks),将app与wendor这两个chunk中公共模块提取出来。 (3)由于vendor仅仅只包含第三方模块,这部分不会经常改动,因此可以有效地利用客户端缓存,在用户后续请求页面时会加快整体的渲染速度。 三、配置资源出口
(1)作用:控制输出资源的文件名。其形式为字符串。 (2) 可以是一个相对路径,即便路径中的目录不存在也没关系,webpack会在输出资源时创建该目录。 (3)在多入口时,需要为对应产生的每个bundle指定不同的名字,webpack支持使用一种类似模板语言的形式动态地生成文件名。
a、【name】会被替换为chunk name。 b、其他集中模板变量
作用: (1)当有多个chunk存在时对不同的chunk进行区分。 (2) 控制客户端缓存。
path可以指定资源输出的位置,要求值必须为绝对路径
?(1)作用:指定资源的请求位置。 (2)请求位置:由JS或CSS所请求的间接资源路径。(页面中的资源分为两种,一种是由HTML页面直接请求的,比如通过script标签加载的JS,另一种是由JS或CSS请求的,如异步加载的JS,从CSS请求的图片字体等) (3)有3中形式
|
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/11 4:10:23- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |