webpack核心特性 - loader

158 阅读3分钟

(空席)

常用加载器分类

  1. 编译转换类
  2. 文件操作类
  3. 代码检查类

编译转换类:将如css类的代码通过加载器转化为 js 代码在输出文件中以js模块的形式运行css。

文件操作类:将资源文件拷贝到输目录,然后将文件的访问路径向外导出。

代码检查类:代码质量检查,用于统一代码风格。

资源模块加载

loader 是 webpack 模块打包的核心特性。

通过不同的 loader 就可以加载不同类型的资源

webpack 内部加载器的loader 默认打包项目中的 js 文件,如果打包其他格式的文件,需要下载对应的加载器loader的插件。最终打包过后的文件都会以模块的形式打包到一个 js 文件中。

webpack默认打包原理: 微信截图_20210520104657.png

js 文件和其他格式资源文件合并打包: 微信截图_20210520104657.png 注:所有资源模块最终都会合并到一个导出的js文件中:bundle.js

css文件加载器插件

1、css-loader

功能:打包 .css 文件

下载

$ yarn add css-loader --dev

配置

// webpack.config.js
const path = require('path')

module.exports = {
    mode: 'none',                   // 指定打包后的文件的样式类型
    entry: './src/main.css',        // 指定打包入口文件
    output: {                       // 定义导出文件
        filename: 'bundle.js',
        path: path.join(__dirname, 'dist')  // 绝对路径
    },
    module: {                       // 模块加载配置
        rules: [                    // 定义配置规则
            {
                test: /.css$/,      // 定义打包以.css结尾的文件
                use: 'css-loader'   // 指定使用哪个加载器loader
            }
        ]
    }
}

2、style-loader

功能:将 css-loader 转换的结果通过style标签的形式添加到页面,css样式最终才能渲染到页面上

下载

$ yarn add style-loader --dev

配置

// webpack.config.js
const path = require('path')

module.exports = {
    mode: 'none',                   // 指定打包后的文件的样式类型
    entry: './src/main.css',        // 指定打包入口文件
    output: {                       // 定义导出文件
        filename: 'bundle.js',
        path: path.join(__dirname, 'dist')  // 绝对路径
    },
    module: {                       // 模块加载配置
        rules: [                    // 定义配置规则
            {
                test: /.css$/,      // 定义打包以.css结尾的文件  
                use: [              // 指定使用哪个加载器loader
                    'style-loader',
                    'css-loader'    // 当有多个加载器loader时,执行顺序从后往前依次执行
                ]
            }
        ]
    }
}

导入资源模块

其实 webpack 正确的打包流程(webpack打包思想)还是通过 main.js 作为打包入口文件(相当于应用的运行入口),在 js 文件中通过 import 关键字导入需要的资源文件。

原理:将css代码通过 css-loader 和 style-loader 加载器转化为js代码,在js中执行

代码:

//************ main.js ****************
import createHeading from './heading.js'
// 导入 css 资源文件
import './main.css'

const heading = createHeading()

document.body.append(heading)
//*************************************

//************ main.css ***************
body{
    color: slateblue;
    background-color: thistle;
    margin: 30px;
}
//*************************************

//************ heading.js ************
// 导入依赖的 css 文件
import './heading.css'

export default () => {
    const element = document.createElement('h1')
    element.textContent = '你好!'
    // 添加 heading.css 文件中的 heading 类名
    element.classList.add('heading')
    element.addEventListener('click', () => {
        alert('hello')
    })
    return element
}
//*************************************

//************ heading.css ************
.heading {
    padding: 10px;
    background-color: #343a40;
    color: #fff;
}
//*************************************

文件资源加载器

除了上面的可以将 css 代码可以转化为js代码执行的加载器,还有字体、图片等不能转为js代码的资源文件,webpack也有相应的文件资源加载器loader。

图片文件资源加载器

1、file-loader

工作原理:webpack 在打包时遇到了图片文件,然后根据webpack.config.js配置文件中的配置,匹配到了文件加载器,加载器导入的文件拷贝到输出目录,将文件在输出目录中的路径作为当前模块的返回值返回,导入的资源就可以被发布出去了。

下载

yarn add file-loader --dev

代码:

// 导入图片资源
import icon from './icon.png'

// 创建图片对象,添加到body
const img = new Image()
img.src = icon
document.body.append(img)

// *********** webpack.config.js 配置文件 ***************
const path = require('path')

module.exports = {
    mode: 'none',                   // 指定打包后的文件的样式类型
    entry: './src/main.js',        // 指定打包入口文件
    output: {                       // 定义导出文件
        filename: 'bundle.js',
        path: path.join(__dirname, 'dist'),  // 绝对路径
        // publicPath: 'dist/'      // 新版本 file-loader 可以不指定默认路径
    },
    module: {                       // 模块加载配置
        rules: [                    // 定义配置规则
            {
                test: /.css$/,      // 定义打包以.css结尾的文件  
                use: [              // 指定使用哪个加载器loader
                    'style-loader',
                    'css-loader'    // 当有多个加载器loader时,执行顺序从后往前依次执行
                ]
            },
            {
                test: /.png$/,
                use: 'file-loader'
            }
        ]
    }
}

2、Data Urls:url-loader

Data Urls 特殊的资源形式,通过 url 的形式表示一个文件资源。

原理:同 file-loader 加载器工作原理,只不过导出时资源形式不同。

格式: 微信截图_20210520193208.png 示例:

微信截图_20210520193208.png

下载

yarn add url-loader --dev

配置

配置:use: 'url-loader'

rules: [                    // 定义配置规则
            {
                test: /.css$/,      // 定义打包以.css结尾的文件  
                use: [              // 指定使用哪个加载器loader
                    'style-loader',
                    'css-loader'    // 当有多个加载器loader时,执行顺序从后往前依次执行
                ]
            },
            {
                test: /.png$/,
                use: 'url-loader'
            }
        ]

输出:以url的形式展示资源文件

<img src="">

url-loader 使用的最佳实践:

小文件使用 url-loader 加载器的方式渲染,减少服务器的请求次数;
大文件通过 download 的方式提高加载速度。

代码:

rules: [                    // 定义配置规则
            {
                test: /.png$/,
                // use: 'url-loader'
                use:{
                    loader: 'url-loader',
                    options: {
                        limit: 10 * 1024  // 10 kb
                    }
                }
            }
        ]

通过配置文件中的 options 配置选项中 limit 属性,指定小于10KB的图片通过 url-loader 加载,而超过10KB的图片,url-loader 加载器还是给 file-loader 去处理(前提是两个 loader 都需要下载,以满足不同大小的文件)

webpack ES6语法转换loader

插件:babel-loader,同时需要这个loader缩依赖的loader:@babel/core@babel/preset-env

实现将ES6+新语法转换为对浏览器更友好的ES5版本语法

安装:

yarn add babel-loader @babel/core  @babel/preset-env --dev

配置:

 rules: [                    // 定义配置规则
            {
                test: /.js$/,
                use: {
                    loader: 'babel-loader',
                    options: {
                        presets: ['@babel/preset-env']
                    }
                }
            }
         ]