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

免费传奇网站免费传奇云空间的网站

免费传奇网站免费传奇,云空间的网站,18款未成年禁止下载的app,短网址压缩📝个人主页:爱吃炫迈 💌系列专栏:前端工程化 🧑‍💻座右铭:道阻且长,行则将至💗 文章目录 loaderloader引入方式loader传入/接收参数传入参数接收参数 loader返回值retur…

📝个人主页:爱吃炫迈
💌系列专栏:前端工程化
🧑‍💻座右铭:道阻且长,行则将至💗

文章目录

  • loader
  • loader引入方式
  • loader传入/接收参数
    • 传入参数
    • 接收参数
  • loader返回值
    • return source
    • this.callback()
  • 同步/异步loader
    • 使用async和await进行处理
    • 使用loader提供的this.async进行处理
  • loader单一功能原则
  • loader实战
    • style-loader
    • css-loader
    • less-loader


loader

一个loader就是一个Node.js模块,这个模块需要导出一个函数,这个导出函数的工作就是获得处理前的源内容,对源内容进行处理后,返回处理后的内容

实现一个替换文件中姓名的loader。例如将“小张”替换成“小李”

name.js

export const name = "小张"

index.js

import { name } from "./name.js"function showInfo() {console.log("name")
}showInfo()

运行代码输出:

小张

现在我们希望将小张替换成小李:

  1. 创建replace-loader

myLoaders/replace-loader.js

module.exports = function(source) {// source为compiler传递给loader的一个文件的源内容const cotent = source.replace("小张", "小李")// 该处理函数需要返回处理后的内容return cotent
}
  1. 使用loader

webpack.config.js

const path = require("path")module.export = {mode: "production",entry: "./src/index.js",output: {path: path.resolve(__dirname, "dist"),filename: "[name].js",},module: {rules: [{test: /\.js$/,use:"./myLoaders/replace-loader.js"// 本地loader, 要填写本地的路径}]},
}

打包后我们就会发现实现我们的想要的功能啦~~~

因为我们使用的是本地的loader,因此需要填写本地的路径。loader的引入主要有以下几种方式:

loader引入方式

  1. 如果是npm包安装的loader,那么直接写loader名称即可
{test: /\.js$/,use:'babel-loader'
}
  1. 如果是本地自定义的loader,那么需要写本地loader的地址
{test: /\.js$/,use: path.resolve(__dirname, "./myLoaders/replace-loader")
}

如上面的代码,我们每使用一个自定义的loader,都必须使用 path 模块来解析自定义loader的路径问题,这就会导致代码变得难以维护。那可不可以像引用第三方的loader一样,只写loader 名呢?我们可以使用 resolveLoader 来解决这个问题。

  1. 如果是本地定义的loader,然后也想直接使用loader名称,那么可以取个别名
module.exports = {resolveLoader: {// 取个别名alias: {"replace-loader": path.resolve(__dirname,"myLoaders/replace-loader")}},module: {rules: [{test: /\.js$/,use: 'replace-loader',}]}
}
  1. 如果你不想取别名,还想直接使用loader,那么就定义一下loader的查找位置,loader会默认先从node_modules中查找。如果我们希望它也能够到本地查找,那么就定义一下查找位置。

ResolveLoader 用于配置 webpack 如何寻找 loader,默认情况下只会去 node_modules 目录下寻找,为了让 webpack 去加载自定义的 loader,我们需要修改 resolveLoader.modules

比如我们自定义的loader 放在 ./myLoaders 目录下,则需要如下配置:

module.exports = {resolveLoader: {// 去哪些目录下寻找 loader ,有先后顺序之分// 如下配置中,查找顺序是:先在 node_modules 目录下寻找,若找不到,再到 ./myLoaders 目录下寻找modules: ["node_modules", "./myLoaders"],},module: {rules: [{test: /\.js$/,use: 'replace-loader',}]}
}

loader传入/接收参数

传入参数

我们上述代码的功能是将“小张”替换成“小李”,假如我们希望将“小张”替换成“小王”,换成“小周”,那么我们难道每次都在loader中修改吗?这肯定不会,因此,我们需要支持配置参数。loader支持通过options进行配置:

{test: /\.js$/,use: ["replace-loader",{loader: "replace-loader",options: {name: "小李",},},],
}

接收参数

  1. this.query

webpack官方文档如何让编写一个loader中说明了loader只接收一个参数,这个参数是读取的文件内容(一个包含资源文件内容的字符串)。webpack会把所有的信息都放到上下文this中,我们可以通过this.queryAPI来获取webpack.config.js中配置的options对象:

module.exports = function (source) {// this.query 获取到的就是在webpack.config.js配置中配置的 options 对象// 通过 this.query API 获取在配置中配置的 name return source.replace("小张", this.query.name);
};
  1. loader-utils

虽然我们可以通过this.query来进行获取,但是webpack更加推荐使用loader-utils来进行操作,它提供了许多有用的工具,最常用的一种工具是获取传递给loader的选项。

  • 安装
npm i loader-utils -D
  • 使用
const { getOptions } = require('loader-utils')
module.exports = function(source)  {// const options = this.getOptions();let { name } = getOptions(this);const content = source.replace("小张",name);return content;
}

loader返回值

loader 的原理就是将输入的源内容进行处理后返回,loader的返回值涉及到一个还是多个返回值。有些情况下比如我们需要返回sourceMap,那么就需要多个返回值。 如果需要返回一个返回值,可以直接使用return。

return source

如果只有一个返回值,可以使用return返回,这种方式返回的是源内容转换后的内容

const { getOptions } = require('loader-utils')
module.exports = function (source) {// 处理sourcelet { name } = getOptions(this)const content = source.replace("小张", name)return content // 返回一个值
}

this.callback()

如果有多个值需要返回,需要使用loader本身提供的回调函数callback。这种方式可以返回除了处理内容之外的其他信息。

const { getOptions } = require('loader-utils')
const { SourceMap } = require('module')module.exports = function (source) {// 处理 sourcelet { name } = getOptions(this)const content = source.replace("小张", name);// 使用 this.callback 返回内容this.callback(null, content,SourceMap);
};

callback支持的参数如下:

callback({// 报错error: Error | Null,// 转换后的内容content: String | Buffer,// 转换后的内容得出的sourceMapsourceMap?: SourceMap,// astabstractSyntaxTree?: AST 
})

注意:

在Webpack中,每个loader都可以返回一个包含多个属性的对象。

  • content是该对象的一个属性,用于指定经过loader处理后生成的代码。
  • sourceMap是另一个属性,用于指定生成的代码的源映射表。

因此,content和sourceMap的区别在于,content是经过loader处理后生成的代码本身,而sourceMap则是一个包含了生成的代码和原始代码的映射关系的JSON对象。

事实上,如果只有一个返回值,我们也可以直接使用this.callback。

this.callback(null,content)

同步/异步loader

loader有同步异步之分,上面介绍的loader都是同步loader,因为它们的转换流程都是同步的,即转换完成后再返回结果。但在某些场景下转换内容需要异步才能完成,例如需要通过网络请求才能得到结果,如果使用同步的方式,网络请求就会阻塞整个构建过程,导致构建变得十分缓慢。

使用async和await进行处理

module.exports = async function(source)  {let {name,age} = getOptions(this);// 这里其实不是异步的,只是作为示例,可以这样处理const content =  await source.replace("小张",name);return content;
}

使用loader提供的this.async进行处理

当转换内容需要异步才能完成时,我们可以使用webpack为loader提供的this.async将这个loader变成是一个异步loader:

const { getOptions } = require('loader-utils')
const { SourceMap } = require('module')module.exports = function (source) {let { name } = getOptions(this);// 使用 setTimeout 模拟异步过程setTimeout(() => {const content = source.replace("小张", name);// 通过 callback 返回执行异步后的结果this.async(null, content,SourceMap);}, 3000);
};

loader单一功能原则

在webpack官网的如何编写一个loader中提到,webpack的loader编写最寻单一功能原则,也就是loader只能实现一个功能。比如less-loader用来处理less文件,css-loader用来处理css文件,style-loader用来将样式插入到style标签中,这些功能虽然可以放到一个loader中实现,但是为了确保loader的功能纯粹,能够让不同的loader各司其职,同时进行功能组合,最好每个loader只负责一个功能。

loader实战

style-loader

style-loader做的事情其实很简单,就是把序列化后的css内容放到style标签中,然后将style标签插入到HTML页面的head标签中

module.exports = function(source) {return `const styleTag = document.createElement('style');styleTag.innerHTML = ${source};document.head.appendChild(styleTag);`
}

css-loader

css-loader 做的事情也十分的简单,将 less-loader 转换后的 css 内容进行序列化

module.exports = function(source) {return JSON.stringify(source);
}

less-loader

less-loader 做的事情就是使用 less 模块,将 less 转换成 css

// 使用 less 模块处理 less 语法
const less = require('less');
module.exports = function(source) {less.render(source, (error, output) => {let { css } = output;this.callback(error, css)})
}

参考文章:
由浅及深实现一个自定义loader

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

相关文章:

  • 衡水网站推广抖音小程序源码
  • 石家庄网站建设 河北供求网网站利用百度离线地图
  • 乐山 网站建设电脑软件制作入门教程
  • 网站设计制造深圳网站关键词
  • 兰州网站seo技术厂家企业咨询培训
  • 网站推广风险wordpress 标题截取
  • 安阳淘宝网站建设WordPress tag 分类
  • 舆情分析网站房管局网站建设方案
  • html5建设的网站个人做电商网站需要备案吗
  • 松原网站制作佛山网页模板建站
  • 数控机床网站建设高效网站推广设计
  • 网站推广适合哪种公司做做网站用花生壳哪个版本
  • 33岁改行做网站建设打工网站校企合作建设
  • 爱奇艺影业公司网站开发意义如何看出一个网站有做seo
  • 个人网站制作软件哪个好浙江住建局官方网站
  • wordpress建站 外贸如何搭建网上商城
  • 选择锦州网站建设怎么找需要推广的商家
  • 网站服务器上线后要怎么做wordpress销量最高主题
  • 网站建设 微盘长沙百度网站推广优化
  • 网站开发著作权wordpress淘宝i主题
  • 做网站找个人还是找公司网站建设源码修改
  • 申请网站一年多少钱哈尔滨网页制作人才招聘
  • 绿色大气网站模板做网站页面的需要哪些技巧
  • 常州市网站优化网站建设公司网址
  • 建立网站平台pc 手机网站建设
  • html搭建网站网站中英文转换js
  • 做百度竞价网站修改影响排名吗免费汽车租赁网站模板
  • 嘉盛建设集团官方网站红安县城乡建设局网站
  • 临沂小学网站建设ssh框架做的家政服务网站
  • 建设网站需要哪些费用大学部门宣传视频创意