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

互力互通网站建设/官网优化包括什么内容

互力互通网站建设,官网优化包括什么内容,漳州网站设计制作,网站备案链接直接查看如何实现一个Loader? 我们在上几节有讲过loader,今天我们来深入了解它们,最暴力的方式莫过于动手实现它们 好了,回到正题, 先来回顾一下loader loader定义: 用于对模块的源代码进行转换。loader 可以使你在 import 或"加载"模块时预处理文件…

如何实现一个Loader?

我们在上几节有讲过loader,今天我们来深入了解它们,最暴力的方式莫过于动手实现它们

好了,回到正题, 先来回顾一下loader

loader定义: 用于对模块的源代码进行转换。loader 可以使你在 import 或"加载"模块时预处理文件

简单使用

module.exports = {//...module: {rules: [{test: /\.js$/,use: [{// loader 是导出为一个a函数的 node 模块。该函数在 loader 转换资源的时候调用// 给定的函数将调用 loader API,并通过 this 上下文访问loader: path.resolve('loader.js'),options: {/* ... */}}]}]}
};

回顾了loader的定义及简单使用后,我们再来分析一下实现loader的思路

  • 单一职责,一个loader只做一件事
  • 链式组合,链中的每个 loader 会将转换应用在已处理过的资源上
  • 模块化,是导出为一个函数的 node 模块
  • 参数合并,loader 可以通过 options 对象配置

基于上面分析的几点,我们开始动手

// 这个就是一个最简单loader,
// 如果我们的loader有依赖其它模块,也得以module的写法将在在顶部引入
import fs from 'fs';
export default function(source){return source
}

我们发现上面直接使用了return,是因为是同步类的loader且返回的内容唯一,如果你希望你的loader支持链式调用,将结果返给下一个loader继续使用,这时候就需要用webpack提供的api

这里我们简单看一下this.callback的定义,一个可以同步或者异步调用的可以返回多个结果的函数。预期的参数是

this.callback(err: Error | null,content: string | Buffer,sourceMap?: SourceMap,meta?: any
)
// loader-utils 它提供了很多有用的工具
// 最常用的一个就是获取传入 loader 的 options
import { getOptions } from 'loader-utils';
export default function(source, other) {const options = getOptions(this)    // do whatever you want// ...this.callback(null, source, other)
}

手写一个loader对没有研究过的听上去好像有点难,事实上, 掌握上面所介绍的内容及思想,就可以开始写一个简单的 Loader 了, 我们再来用简单的代码绥一下loader到底是什么?

// 首先loader它是一个node模块,这很好理解
export const lessToCss = function(source, other) {// source 就是你即将要转换的文件源// TODO// 将转换好的文件源流转至一个管道this.callback(null, source, other)
}

让你的loader更好用

loader api中有几个好用的家伙这里就顺便带一下

  • this.cacheable() 从提高执行效率上,如何处理利用缓存是极其重要的, webpack 中this.cacheable就可以轻松将loader缓存了
  • this.async() 当一个loader无依赖时,我们应该异步的去返回结果

案例分析

下方贴上less-loader的源码,代码很简洁,结合上方我们所分析的,也很容易理解

import processResult from './processResult';
const render = pify(less.render.bind(less));function lessLoader(source) {const loaderContext = this;const options = getOptions(loaderContext);const done = loaderContext.async();const isSync = typeof done !== 'function';if (isSync) {throw new Error('Synchronous compilation is not supported anymore. See https://github.com/webpack-contrib/less-loader/issues/84');}processResult(loaderContext, render(source, options));
}

总结

  • loader是一个node模块
  • 编写loader时要遵循单一原则,每个loader只做一种"转义"工作
  • webpack为我们提供了丰富的loader api
  • webpack为我们还提供了工具函数集——loader-utils

关于JS每日一题

JS每日一题可以看成是一个语音答题社区 
每天利用碎片时间采用60秒内的语音形式来完成当天的考题 
群主在次日0点推送当天的参考答案

  • 注 绝不仅限于完成当天任务,更多是查漏补缺,学习群内其它同学优秀的答题思路

原文https://segmentfault.com/a/1190000018745920?utm_source=tuicool&utm_medium=referral

http://www.lbrq.cn/news/1428715.html

相关文章:

  • 成都网站建设 冠辰/2021年经典营销案例
  • 网站建设销售销售流程/商丘 峰少 seo博客
  • 怎样给公司做网站/网络营销的渠道有哪些
  • 农家乐网站建设营销方案/百度电脑端网页版入口
  • 手机网站绑定域名是什么意思/快速排名官网
  • 大数据比赛网站建设/台州seo网站排名优化
  • 网站发帖推广平台/公司网站设计模板
  • php网站怎么做/seo排名助手
  • 网络规划设计师试题/百度网站排名关键词整站优化
  • 做游戏的av迅雷下载网站有哪些/成人大学报名官网入口
  • 网站建设的流程分析/公司网站推广运营
  • aspcms自适应网站/查域名ip地址查询
  • 免费域名如何建站/手机网站模板下载
  • 做瞹瞹瞹视频免费网站/百度推广的定义
  • 深圳公司网站开发/百度网页版入口链接
  • 自己做彩票网站吗/网站seo推广方案
  • 绍兴公司网站建设 中企动力绍兴/seo哪里可以学
  • 溧阳做网站价格/ip域名解析查询
  • 营销型网站套餐/seo蜘蛛池
  • 我做外贸要开国际网站吗/app软件开发
  • 广告营销图片/佛山网站优化软件
  • 具体的网站建设方案/小广告设计
  • wordpress火车采集/seo优化信
  • 找手工活做注册网站/推广放单平台
  • 最新wordpress新建首页/神马seo教程
  • 做网站谁家好/搜索引擎优化简历
  • 美国服务器购买网站/关键词优化公司排名榜
  • 长沙有名的公司/百合seo培训
  • b站户外打野/整合营销推广
  • 途牛网站建设方案/线上it培训机构
  • Python爬取推特(X)的各种数据
  • 【Canvas与玻璃光】铝圈蓝底玻璃光按钮
  • 启动electron桌面项目控制台输出中文时乱码解决
  • zabbix部署问题后常见问题
  • 切换VSCODE 中的默认 shell
  • Java 大视界 -- Java 大数据机器学习模型在金融欺诈检测与防范策略制定中的应用(397)