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

网站seo快速优化技巧自媒体人专用网站

网站seo快速优化技巧,自媒体人专用网站,中国企业集成网,建设网络良好生态心得体会什么是loader?什么是plugin? loader 本质为一个函数,将文件编译成可执行文件。webpack完成的工作是将依赖分析与tree shinking对于类似.vue或.scss结尾的文件无法编译理解这就需要实现一个loader完成文件转译成js、html、css、json等可执行文…

什么是loader?什么是plugin?

  • loader 本质为一个函数,将文件编译成可执行文件。webpack完成的工作是将依赖分析与tree shinking对于类似.vue或.scss结尾的文件无法编译理解这就需要实现一个loader完成文件转译成js、html、css、json等可执行文件。
  • plugin可以是函数或Class(es6),通过订阅webpack串行流程上的事件,实现扩展webpack功能,改变webpack输出结果。

区别:

  1. 执行时机不同。loader主要是倒序执行,从后往前将一个loader的输出作为它前一个loader的输入,直到运行完所有loader;plugin执行执行时机在与通过订阅webpack串行流程上的事件,当webpack运行到对应订阅事件时执行,可以运行在整个生命周期内。两者都可以同步或者异步执行。
  2. 侧重功能不同。loader主要完成文件操作;plugin主要是实现除loader以外功能,扩展webpack功能。
  3. 配置方式不同。loader配置到module.rules,rules是一个数组,每一个元素是一个对象,每个对象包含属性test(检验目标文件类型)、use:(loader数组,从后往前执行)、options(配置);plugin放在plugins数组中通过new 关键字创建。
  4. 书写方式不同。

​ loader编写伪代码如下

/*** 定义一个loader* 1.不可为一个箭头函数,Webpack运行时需要指定运行this为Webpack,所以可以调用内置api* 2.可以异步返回使用this.callback* 3.配置的options可以使用this.query获取* @param source 模块文件源数据内容* @return {*}*/
module.exports = function (source) {// 如果 loader 配置了 options 对象,那么this.query将指向 optionsconst options = this.query;const doTask = async (source) => {//伪代码进行数据转换const content = await source2Something(source,options)/** this.callback 参数:* error:Error | null,当 loader 出错时向外抛出一个 error* content:String | Buffer,经过 loader 编译后需要导出的内容* sourceMap:为方便调试生成的编译后内容的 source map* ast:本次编译生成的 AST 静态语法树,之后执行的 loader 可以直接使用这个 AST,进而省去重复生成 AST 的过程*/this.callback(null, content)}//异步返回结果doTask()//同步返回return source2Something(source,options)
}

​ plugin编写伪代码如下

/*** 定义一个plugin* 1.需要通过new创建可以使用class创建* 2.内部需要有一个方法apply调用运行插件功能* * 具体可以看* https://webpack.docschina.org/contribute/writing-a-plugin/#basic-plugin-architecture*/class MyPlugin {//创建时可以传入参数constructor(options) {this.options = options;}/*** 通过compiler获取 webpack 内部的钩子,获取 webpack 打包过程中的各个阶段* 钩子分为同步和异步的钩子,异步钩子必须执行对应的回调* @param compiler*/apply(compiler){//同步hook 最后调用tap//emit为hook事件名称compiler.hooks.emit.tap('MyPlugin',compilation=>{//do somethings//do somethings//do somethings})//异步hook 最后调用tapAsync、tapPromise//done为hook事件名称//tapAsync 异步钩子必须执行对应的回调//tapPromise 需要返回Promisecompiler.hooks.done.tap('MyPlugin', (compilation, callback) => {console.log("打包已完成");//do somethings//do somethings//do somethingscallback();})}}

http://www.jinmujx.cn/news/119606.html

相关文章:

  • java做软件的网站怎么营销一个产品
  • 网页设计首页怎么设计seo网站关键词优化方式
  • 比较好约的网站设计企业网站建设制作
  • 松江网站建设多少钱下载优化大师app
  • 天河网站建设制作爱网站关键词挖掘
  • 网站建设昆明包装设计竞价推广怎样管理
  • 自己做网站语言包怎么做网络营销的优势有哪些?
  • 室内设计平台接单电脑清理优化大师
  • 如何建造企业网站搜关键词网站
  • 深圳哪家做网站免费推广公司
  • 中国建设银行网站怎么登录不上东莞seo网站排名优化公司
  • 东莞建设网站的公司今天晚上19点新闻联播直播回放
  • 无锡哪里做网站搜索百度app下载
  • 优化网站浏览量怎么看免费职业技能培训网站
  • dw是做静态网站还是动态的怎么在网上做广告
  • 外贸独立网站设计扬州seo博客
  • 一级做爰片a视频网站4今日头条新闻
  • 网站建设 页面软文投放平台有哪些?
  • 做蛋糕的网站排名优化哪家专业
  • 嘉善网站建设app线上推广是什么工作
  • 有些人做网站不用钱的 对吗seo排名赚
  • 网站主页设计要点seo推广计划
  • 模板网站建设合同网络广告推广
  • 那些网站可以做推广seo是指什么职位
  • 免费建设网站赚钱怎样推广自己的店铺啊
  • 奉贤免费网站建设优秀网站
  • vs2017做网站工作手机
  • 西安做网页的seo排名助手
  • 手机无法访问wordpress优化网站的方法
  • 什么网站做玩具的比较多看网站时的关键词