当前位置: 首页 > news >正文

盱眙网站制作行业资讯网站有哪些

盱眙网站制作,行业资讯网站有哪些,网络推广服务合同模板,西安网站推广webpack的loader机制 loader本质上就是导出函数的JavaScript模块。导出的函数,可以用来实现内容的转换。 /* * param{string|Buffer} content 源文件的内容 * param{object} [map] SourceMap数据 * param{any} [meta] meta数据,可以是任何数据 * */ fu…

webpack的loader机制

loader本质上就是导出函数的JavaScript模块。导出的函数,可以用来实现内容的转换。

/*
* @param{string|Buffer} content 源文件的内容
* @param{object} [map] SourceMap数据
* @param{any} [meta] meta数据,可以是任何数据
* */
function webpackloader(context, map, meta) {}module.exports = webpackloader()

Normal Loader

Normal Loader: 按照正常的顺序去执行的loader
use参数,表示匹配到test中匹配对应的文件应该使用那个loader的队则去处理,use可以为一个字符串也可以为一个数组,use为一个数组的时候,表示有多个loader一次处理匹配的资源,按照从右到左,从下到上执行
如果要改变执行顺序的话,需要使用enforce参数来改变loader的执行顺序,pre前置,post后置,normal普通和inline行内
在这里插入图片描述

在这里插入图片描述

Pitching Loader

在webpack的loader中配置pitch属性,支持三个参数

/*
* @remainingReqquest 剩余请求
* @precedingRequest 前置请求
* @data 数据对象
* */
function webpackloader(remainingRequest, precedingRequest, data) {// some code
}

data用于数据参数,在pitch函数中往data对象上添加数据,之后在normal函数中通过this.data的方法读取已经添加的数据。
remainingRequest 表示在当前 loader 处理完毕后,还需要被后续 loader 处理的请求字符串。这个字符串由剩余的 loader 路径以 ! 分隔符组成,从右到左排列。例如,在配置 use: [‘loaderA’, ‘loaderB’] 时,如果当前 loader 是 loaderB,那么 remainingRequest 就是 ‘loaderA!’(如果还有其他 loader,则继续以 ! 分隔)。
precedingRequest 表示在 pitch 阶段已经迭代过的 loader 路径字符串,同样以 ! 分隔符组成。这个字符串表示在当前 loader 的 pitch 方法被调用之前,已经有哪些 loader 的 pitch 方法被调用过
关于loader的执行阶段分为两个阶段

  • 在处理资源文件之前,会经历pitch阶段
  • pitch结束之后,读取资源文件内容
  • 经过pitch处理后,读取到了资源文件,此时才会将读取到的资源文件内容交给正常的loader进行处理
module.exports = {module: {rules: [{test: /\.js$/,use: ['normal1-loader', 'normal2-loader']},{test: /\.js$/,use: ['pre1-loader', 'pre2-loader'],enforce: 'pre'},{test: /\.js$/,use: ['post1-loader', 'post2-loader'],enforce: 'post',}]}
}

在这里插入图片描述

故loader的执行顺序就是pitching阶段,调用loader.pitch方法, 该方法还可以有返回值,normal阶段,执行loader本身函数,模块源码的转换,发生在这个阶段
pitching loader的熔断机制
根据当前 loader 对象 pitch 函数的返回值是否为 undefined 来执行不同的处理逻辑。如果 pitch 函数返回了非 undefined 的值,则会出现熔断。即跳过后续的执行流程,开始执行上一个 loader 对象上的 normal loader 函数。

http://www.yayakq.cn/news/616102/

相关文章:

  • 昆明市网站推广淮北信息网官方
  • 学做投资网站好创建网站需要哪些要素
  • 人是用什么做的视频网站百度竞价排名软件
  • wordpress网站搬网站头部固定
  • 做外贸学网站小程序开发教程推荐
  • 网站建设与维护网课安徽省建设工程信息网官方网站
  • 注册域名网站网站为什么要服务器
  • 重庆城乡建设网站ppt制作入门教程
  • 做网站需要用什么开发软件网站做的题不小心关闭了
  • 做网站是需要多少钱界面设计效果图排版
  • 做资讯类网站需要特殊资质吗大数据平台网站建设
  • 东营网站app建设展馆设计施工一体化
  • ai做漫画头像网站购买淘宝店铺在哪个平台
  • 建设目标网站线上推广有哪些渠道
  • 网站推广预期达到的目标wordpress文章不发在首页
  • 广州天河做网站商丘做网站需要多少钱
  • 让路由器做网站服务器wordpress短链识别
  • 建网站需要多钱市场推广怎么做
  • 临沂网站建设多少钱成都网站制作公司定制
  • 公司网站导航栏是什么科技感办公室设计
  • 桂林北站改造最新方案网络规划与设计需求分析
  • 本地的天津网站建设龙元建设集团股份有限公司网站地址
  • 苏州诗华洛网站建设空间设计英文
  • 福州响应式网站建设和老妇做爰视频网站
  • 网站开发背景设置php网站制作商品结算怎么做
  • 威海制作网站网站网站做庄是怎样做
  • 怎么做微信点击网站打赏看片为什么要做网站优化
  • 网站建设方案书阿里云企业网站建设的总体目标
  • html5网站开发icp备案网站名称
  • 广西桂林网站建设房产达人