【Vue】1-3、Webpack 中的 loader

一、概述

在实际开发过程中,webpack 默认只能打包处理以 .js 后缀结尾的模块。

其他的非 .js 后缀名结尾的模块 webpack 默认处理不了,需要调用 loader 加载器才可以正常打包,否则会报错!

loader 加载器的作用 :协助 webpack 打包处理特定的文件模块。

  • css-loader 可以打包处理 .css 相关文件

  • less-loader 可以打包处理 .less 相关文件

  • babel-loader 可以打包处理 webpack 无法处理的高级 js 语法

二、打包处理 css 文件

步骤:

1)运行 npm install style-loader@3.0.0 css-loader@5.2.6 -D 命令,安装处理 css 文件的 loader

2)在 webpack.config.jsmodule -> rules 数组中,添加 loader 规则如下:

javascript 复制代码
module:{	// 所有第三方文件模块的匹配规则
	rules: [	// 文件后缀名的匹配规则
		{
			test:/\.css$/,
			use:['style-loader','css-loader']
		}
	]
}

其中,test 表示匹配的文件类型use表示对应要调用的 loader

注意:

use 数组中指定的 loader 顺序是固定的

多个 loader 的调用顺序是:从后往前调用

三、打包处理 less 文件

步骤:

1)运行 npm install less-loader@10.0.1 less@4.1.1 -D 命令

2)在 webpack.config.jsmodule -> rules 数组中,添加 loader 规则如下:

javascript 复制代码
module:{	// 所有第三方文件模块的匹配规则
	rules: [	// 文件后缀名的匹配规则
		{
			test:/\.less$/, 
            use:['style-loader','css-loader','less-loader']
		}
	]
}

四、打包处理样式表中与 url 路径相关的文件

步骤:

1)运行 npm install url-loader@4.1.1 file-loader@6.2.0 -D 命令

2)在 webpack.config.jsmodule -> rules 数组中,添加 loader 规则如下:

javascript 复制代码
module:{	// 所有第三方文件模块的匹配规则
	rules: [	// 文件后缀名的匹配规则
		{
			test:/\.jpg|png|gif$/, 
            use:['url-loader?limit=22229']
		}
	]
}

其中 之后的是 loader 的参数项:

  • limit 用来指定图片的大小,单位是字节(byte

  • 只有 <= limit 大小的图片,才会被转为 base64 格式的图片

五、打包处理 js 文件中的高级语法

webpack 只能打包处理 一部分高级的 JavaScript 语法。

对于那些 webpack 无法处理的高级 js 语法,需要借助于 babel-loader 进行打包处理。

例如 webpack 无法处理下面的 JavaScript 代码:

javascript 复制代码
// 定义了名为 info 的装饰器
function info(target){
	// 为目标添加静态属性 info
	target.info = 'Person info.'
}
// 为 Person 类应用 info 装饰器
@info
class Person{}

// 打印 Person 的静态属性info
console.log(Person.info)

步骤:

1)运行 npm install babel-loader@8.2.2 @babel/core@7.14.6 @babel/plugin-proposal-decorators@7.14.5 -D 命令

2)在 webpack.config.jsmodule -> rules 数组中,添加 loader 规则如下:

javascript 复制代码
module:{	// 所有第三方文件模块的匹配规则
	rules: [	// 文件后缀名的匹配规则
		{
			test:/\.js$/, 
            use:'babel-loader',
            exclude:/node_modules/
		}
	]
}

3)在项目根目录下,创建名为 babel.config.js 的配置文件,定义 Babel 的配置项如下:

javascript 复制代码
module.exports = {
	// 声明 babel 可用的插件
	plugins:[
        [
            '@babel/plugin-proposal-decorators',
            {
                legacy: true
            }
        ]
    ]
}

Babel官网:https://babeljs.io/dosc

一 叶 知 秋,奥 妙 玄 心

相关推荐
罗政5 分钟前
[附源码]超简洁个人博客网站搭建+SpringBoot+Vue前后端分离
vue.js·spring boot·后端
麒麟而非淇淋35 分钟前
AJAX 入门 day1
前端·javascript·ajax
2401_8581205337 分钟前
深入理解MATLAB中的事件处理机制
前端·javascript·matlab
阿树梢42 分钟前
【Vue】VueRouter路由
前端·javascript·vue.js
随笔写2 小时前
vue使用关于speak-tss插件的详细介绍
前端·javascript·vue.js
史努比.2 小时前
redis群集三种模式:主从复制、哨兵、集群
前端·bootstrap·html
快乐牌刀片882 小时前
web - JavaScript
开发语言·前端·javascript
miao_zz3 小时前
基于HTML5的下拉刷新效果
前端·html·html5
Zd083 小时前
14.其他流(下篇)
java·前端·数据库
藤原拓远3 小时前
JAVAWeb-XML-Tomcat(纯小白下载安装调试教程)-HTTP
前端·firefox