博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
从零开始的webpack生活-0x009:FilesLoader装载文件
阅读量:7228 次
发布时间:2019-06-29

本文共 4816 字,大约阅读时间需要 16 分钟。

0x001 概述

上一章讲的是,这一章开始讲loader相关的部分,但是关于plugin的部分善未完结,因为即将要讲的ExtractTextWebpackPlugin用到了一些loader,所以觉得先讲一下loder比较好。

0x002 loader介绍

我比较喜欢装载器这个翻译,loder说白了就是对各种文件的转化而已,比如json-loader可以将loader文件中的内容转化为js对象,也就是可以模拟为读取json文件然后做JSAON.parse而已,而对于其他的装载器则也类似,是对不同文件的不同处理方式,只是他们保持了相同的接口形式。就像一个加工的机器,有一个入口和一个出口,入口放猪肉,出来猪肉制品,入口放鸡肉,出来鸡肉制品,里面如何实现或许不一样,但是操作方式基本一致。

0x003 栗子1-raw-loader:读取文件,并封装成模块,导出唯一的内容为文件内容的字符串

  1. 初始化项目

    $ mkdir 0x009-loader$ cd 0x009-loader$ npm init -y$ cnpm install --save-dev webpack raw-loader
  2. 添加配置

    const path              = require('path');module.exports = {    entry  : {        'index': ['./src/index.js'],    },    output : {        path    : path.join(__dirname, 'dist'),        filename: '[name].bundle.js'    }};
  3. 添加示例文件

    // ./srcindex.txthello loader// ./src/index.jvar content = require('raw-loader!./index.txt')console.log(content)
  4. 打包并查看结果

    $ webpack// ./dist/index.js/***/ }),/* 1 *//***/ (function(module, exports, __webpack_require__) {var content = __webpack_require__(2)console.log(content)/***/ }),/* 2 *//***/ (function(module, exports) {module.exports = "hello loader"/***/ })/******/ ]);

    可以看到,文件的内容被以一个模块的形式导出,而在引入的文件中,变得不再是引入一个文件,而是一个模块。

  5. 不在require中使用loader,因为麻烦且不美观,我们可以把它迁移到webpack.conf.js中。

    • 修改配置文件

      // ./wenpack.conf.jsconst path = require('path');module.exports = {    entry : {        'index': ['./src/index.js'],    },    output: {        path    : path.join(__dirname, 'dist'),        filename: '[name].bundle.js'    },    module: {        rules: [            {                test: /\.txt$/,                use : 'raw-loader'            }        ]    }};
      • test:匹配的文件名,这里匹配后缀为.txt的,只要require了该文件名结尾的文件,都将使用这个raw-loader来处理

      • use:命中后使用的加载器

    • 查看结果,和之前一致,推荐使用wenpack配置文件形式,可以保持引入文件格式的一致性。有利于维护和美观

  6. 更多配置,可以查阅。

0x004 栗子2-json-loader:将json文件转化成js对象

  1. 安装依赖

$ cnpm install --save-dev json-loader
  1. 添加rule配置

    {    test: /\.json$/,    use : loader : 'json-loader'}
  2. 引用

    //./src/index.json{  "name": "张三",  "age": "21"}// ./src/index.jsrequire('./index.json')
  3. 打包并查看结果

    /* 1 *//***/ (function(module, exports, __webpack_require__) {__webpack_require__(2)/***/ }),/* 2 *//***/ (function(module, exports) {module.exports = {"name":"张三","age":"21"}/***/ })/******/ ]);

    可见,json-loder将文件内的json字符串转化成了js对象,相当于使用raw-loader获取文件内容字符串,再调用JSON.parse,然后封装成模块并导出。

0x005 栗子3-file-loader:导出文件并返回文件的URL

  1. 安装依赖包

$ cnpm install --save-dev file-loader
  1. 添加rule配置

    {            test: /\.(png|jpg|gif)$/,            use : [                {                    loader : 'file-loader',                    options: {}                }            ]        }
  2. 引用

    // ./src/index.jsvar funny = require('./../res/funny.png')
  3. 打包并查看结果

    $ ls ./dist4e4e36593ce458606ffd851043749eec.pngindex.bundle.js
    /* 1 *//***/ (function(module, exports, __webpack_require__) {// var content = require('raw-loader!./index.txt')// var content = require('./index.txt')var funny = __webpack_require__(2)/***/ }),/* 2 *//***/ (function(module, exports, __webpack_require__) {module.exports = __webpack_require__.p + "4e4e36593ce458606ffd851043749eec.png";/***/ })/******/ ]);

    可以看出,文件被导出到了dist,并且将文件的路径封装成了模块并导出。

  4. option其他配置

    • name:名字

      • [path]:文件路径

      • [name]:文件名称

      • [hash]:文件hash

      • [ext]:文件后缀

      • 以上变量可以随机组合,形成文件名,推荐:[name].[hash].[ext]

  5. 注意:每引入一个文件,就会生成一个模块,即便该文件只是文件名不同,但是内容相同

  6. 更多配置,可以。

0x006 栗子4-url-loader:根据文件大小类型判断是否DATAURL

  1. 删除file-loader,添加配置

{

test: /\.(png|jpg|gif)$/,            use : [                {                    loader : 'url-loader',                    options: {                        limit   : 1048576, // 低于1m, 这里的单位是Byte                        mimetype: 'image/jpg', // 类型是`jpg`                        name    : '[name].[hash].[ext]',                        fallback: 'file-loader' //否则使用`file-loader`                    }                }            ]        }```
  1. 引入一张高于1048576的jpg图片和1张低于81920的jpg图片,还有一张png图片,da

    // 低于1048576require('./../res/icon.jpg')// 高于1048576require('./../res/big.jpg')
  2. 打包并查看结果

    // ./distbig.f22f26599897a8f5003aea3d070135bf.jpgindex.bundle.js
    // ./index.bundle.js/***/ }),/* 2 *//***/ (function(module, exports) {module.exports = "...tDEx6snNS15Z9DcRe9a1n/AMew+tZI/qK1rP8A49h9a1p7Es//2Q=="/***/ }),/* 3 *//***/ (function(module, exports, __webpack_require__) {module.exports = __webpack_require__.p + "big.f22f26599897a8f5003aea3d070135bf.jpg";/***/ })/******/ ]);

    可以看出大于1m的那个图片文件被以文件的形式导出,而小于1m的文件被以dataurl的形式封装成模块

  3. 参数说明

    • limit:限制文件大小,如果小于这个数,则转化成DATAURL,如果大于这个数,则使用fallback指定的loader再次装载,如果没有配置fallback,则默认调用file-loader

    • mimetype:这个只是用来指定文件的mimetype,因为有些文件没有后缀,或者后缀和文件不符合。

    • fallback:文件超出limit之后的加载器

    • 注意url-loader自身只有这3个参数,但是如果超出limit大小,将会执行下一个loader并且自动将配置的参数往下传,所以文中的案例的name其实是file-loader的参数,其他loader的参数同理也可以往下传

    • 注意:这里的use其实还有另外一种querystring写法,不过不推荐

      {        test: /\.(png|jpg|gif)$/,        use:'url-loader?limit=1045876&name=[name].[hash].[ext]'    }
  4. 更多配置,可以查阅。

0x007. 资源

转载地址:http://rycfm.baihongyu.com/

你可能感兴趣的文章
点击文字,把input type="radio"也选中
查看>>
第一章 Java多线程技能
查看>>
Java 集合系列-第八篇-Map架构
查看>>
springmvc 3.2 @MatrixVariable bug 2
查看>>
React-Native PanResponder手势识别器
查看>>
IOS11 光标错位问题
查看>>
如何设计用户登录
查看>>
linux安装mysql5.7.19
查看>>
Zookeeper+ActiveMQ 集群实现
查看>>
加权有向图问题2----多源最短路径问题(Floyd算法)和关键路径算法
查看>>
logback logback.xml常用配置详解(三) <filter>
查看>>
KgMall B2B/B2B2c/C2C版店铺商号初始化
查看>>
Linux内核的ioctl函数学习
查看>>
Liunx Shell入门
查看>>
Thread的中断
查看>>
linux --- 内存管理
查看>>
PostgreSQL
查看>>
CPU 超线程、多核
查看>>
用ASCII码显示string.xml中的特殊字符
查看>>
网站301跳转到新域名
查看>>