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

深圳做网站公秦皇岛网站建设企业

深圳做网站公,秦皇岛网站建设企业,2021谷歌搜索入口,渝中集团网站建设1、分类 2、执行顺序 配置类型 执行顺序是 loader1>loader2>loader3 3、使用方式 自己的第一个loader 同步loader /*** loader 就是一个函数* 当webpack 解释资源时, 会调用相应的loader去处理* loader 接收到文件内容作为参数,返回文件内容* p…

1、分类

2、执行顺序

配置类型

执行顺序是 loader1>loader2>loader3

3、使用方式

自己的第一个loader

同步loader

/*** loader 就是一个函数* 当webpack 解释资源时, 会调用相应的loader去处理* loader 接收到文件内容作为参数,返回文件内容* @param {*} content 文件内容* @param {*} map SourceMap* @param {*} meta 别的loader 传递过来的数据*/
module.exports = function(content, map, meta){console.log('main.js 传过来的数据', content);return content
}/*** 当需要传递参数给其他 loader 的loader 写法*/// module.exports = function (content,map, meta) {
//     // 第一个参数: err 代表是否有错误
//     // 第二个参数:content 处理后的内容
//     // 第三个参数: source-map 继续传递source-map
//     // 第四个参数:meta 给下一个loader传递参数
//     this.callback(null,content,map,meta);
// }

 会在vscode 终端看到

异步loader (同步loader不能调用异步方法)

module.exports = function(content, map, meta){const callback = this.async()setTimeout(()=>{console.log('异步操作');callback(null, content, map, meta)}, 1000)
}

 raw loader,处理图片、svg等时会用到

// 同步异步操作均可以
module.exports = function(content, map, meta){console.log('raw-loader Buffer数据流', content);return content
}module.exports.raw = true

目前 只有 main.js 文件

console.log('hello word');

patch loader

执行顺序

// pitch-loader1.js
module.exports = function(content, map, meta){console.log('pitch-loader1');return content
}module.exports.pitch = function(content, map, meta){console.log('pitch1');
}//  pitch-loader2.js
module.exports = function(content, map, meta){console.log('pitch-loader2');return content
}module.exports.pitch = function(content, map, meta){console.log('pitch2');
}// pitch-loader.js
module.exports = function(content, map, meta){console.log('pitch-loader3');return content
}module.exports.pitch = function(content, map, meta){console.log('pitch3');
}

webpack.config.js 配置

打印结果

如果patch中有return 则不糊执行后续的操作,而是直接返回到上一个loader执行,如果没有就不用执行,下面是在loader中有返回值的意思,直接返回到loader执行操作

4、loader Api

this.getOptions 获取options

 schema.json

打包后文件中就会多出坐着相关信息

5、简单重写一下常用的部分loader

babel-loader

const babel = require('@babel/core')
const schema = require("./schema.json")module.exports = function(content, map, meta){// 获取webpack 使用这个loader 时的options配置项const callback = this.async()const options = this.getOptions(schema)babel.transform(content, options, function(err, result){if(err) callback(err)else callback(null, result.code)})
}

schema.json

{"type":"object","properties":{"presets":{"type": "array"}},"additionalProperties": false
}

webpack 中的使用

file-loader  (使用到this.emitFile函数)

 webpack 配置

stylle-loader

主要作用,通过js代码创建一个style标签 ,然后将样式代码加进去

这里  module.exports = function(){} 空函数即可

如果,想要更深一步学习loader, 可以去看看常用的loader的源码

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

相关文章:

  • 织梦网站安装视频php网站开发需要多久
  • 网站死链是什么学工系统网站建设的意义
  • 高端定制站开发百度入口的链接
  • 杭州 城西 做网站装酷网
  • 如何在网站申请做co自建网站的流程
  • 购物网站seo搜索引擎优化方案中国菲律宾签证
  • 网站开发与管理所对应的职位及岗位哪个平台建网站比较好
  • 涿州是住房和城乡建设局网站快速建站服务
  • 番禺做网站哪家专业怎么免费做自己的网站
  • 企业网站不付服务费应该怎么做大兴58网站起名网站制作
  • psd简单的网站首页网站宣传活动怎么做
  • 淮北做网站做家装的有没有网站可以找工作
  • 在线教育网站开发实例软件项目过程
  • win2008网站404福州精美个人网站建设公司
  • 合肥的电商网站设计百度推广服务
  • 通常做网站的需求博罗网站设计公司
  • 重庆网站建设的公司中山网页设计
  • 网站的推广方式有哪些免费seo网站的工具
  • 一个网站是怎么做出来的网上国网app下载安装
  • 网站建设算什么服务类型济南建网站价格消费品展
  • 网站开发工具需求南京老牌网站建设公司
  • 网站一般多少钱一年十大软件app排行榜下载
  • 百度网站推广找谁做UE4做购物网站
  • 科大讯飞哪些做教学资源的网站南昌网站建设资讯
  • 哪里的网站建设好点击排名优化
  • 360云盘做服务器建设网站电脑上怎么使用wordpress
  • 深圳房地产网站开发云服务器建设网站
  • 网站开发 家具销售 文献wordpress 代码页面
  • 做英文的小说网站有哪些长沙房地产市场情况分析
  • 集团网站群诚信建设网站的作用