从零开始的webpack生活-0x009:FilesLoader装载文件

智极领航说
• 阅读 1823

0x001 概述

上一章讲的是DLL加速编译,这一章开始讲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.txt
    hello loader
    
    // ./src/index.j
    var 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.js
      const 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. 更多配置,可以查阅webpack关于raw-loader部分

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.js
    require('./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.js
    var funny = require('./../res/funny.png')
  3. 打包并查看结果

    $ ls ./dist
    4e4e36593ce458606ffd851043749eec.png
    index.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. 更多配置,可以查阅webpack关于file-loader部分

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

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

    // ./dist
    big.f22f26599897a8f5003aea3d070135bf.jpg
    index.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. 更多配置,可以查阅webpack关于url-loader部分

0x007. 资源

点赞
收藏
评论区
推荐文章
blmius blmius
4年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
美凌格栋栋酱 美凌格栋栋酱
7个月前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
1年前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
4年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
VSCode配置FiraCode和更纱黑体字体
!(https://oscimg.oschina.net/oscnet/c7bb62d935ceb01d3b7fe176322e84ae00d.png)Fira Code下载到FiraCode字体的GitHub(https://www.oschina.net/action/GoToLink?urlhttps%
可莉 可莉
3年前
18个常用 webpack插件,总会有适合你的!
!(https://oscimg.oschina.net/oscnet/71317da0c57a8e8cf5011c00e302a914609.jpg)来源| https://github.com/Michaellzg/myarticle/blob/master/webpack/Plugin何为插
Stella981 Stella981
3年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这