webpack4.15.1 学习笔记(十) — 常见 loader 使用
style -loader <= css-loader <= less-loader
style-loader 将css样式插入到html中
css-loader 解析import、require 路径处理
less-loader 将less解析为css
{
test: /\.less$/,
use: [{
loader: 'style-loader', // 配置成一个对象
options: {
insertAt: 'top' // 设置解析后的样式 插入html的位置,top为最上面,目的是为了使得用户在html中编写的样式优先级最高
}
}, 'css-loader','less-loader']
},
postcss-loader
配合autoprefixer插件,给css 添加浏览器前缀,需要在解析css代码之前使用。(写在css-loader之后,因为loader执行顺序是从右往左)
需要一个配置文件:postcss.config.js
postcss.config.js
module.exports = {
plugins: [require('autoprefixer')] // 给css添加浏览器前缀
}
{
test: /\.less$/,
use: ['style-loader', 'css-loader', 'postcss-loader', 'less-loader']
},
file-loader
默认会在内部生成一张图片,到build目录下,再返回生成的图片名称,在css中可以直接使用,因为使用了css-loader,会进行require操作,在js文件中使用图片,则需要import 或者require操作。
body {
background: url('./logo.png') /* css-loader 会转换为 url(require('./logo.png')) */
}
// index.js
import logo from './logo'
let image = new Image()
image.src = logo
document.body.appendChild(image)
{
test: /\.(png|svg|jpg|gif)$/,
use: ['file-loader']
},
url-loader
使用url-loader可以对解析的图片的规格进行一些限制。当图片小于 xx K时,用base64来转化,可以减少http请求(但是base64生成的文件,会比源文件大1/3,是base64的特点)。否则是file-loader
{
test: /\.(png|svg|jpg|gif)$/,
use: {
loader: 'url-loader',
options: {
limit:200*1024,
outputPath:'img/',
publicPath: 'http://www.xxx.com' // 资源放至cdn服务器后,可以配置请求域名等
}
}
},
html-withimg-loader
解析html中 引入的图片,
<div>
< img src="./logo.png" /> <-- 会使用打包生成的文件名-->
</div>
{
test: /\.html$/,
use: ['html-withimg-loader']
},
babel-loader
babel默认只转换新的 JavaScript 语法,如箭头函数,不能转换新的 API,如Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise 等全局对象,以及一些定义在全局对象上的方法(比如 Object.assign)都不会转译。
npm install babel-loader @babel/core @babel/preset-env -D
npm install @babel/plugin-proposal-decorators @babel/plugin-proposal-class-properties -D
npm install @babel/plugin-transform-runtime -D
npm install @babel/runtime @babel/polyfill
{
test: /\.js$/,
use: {
loader: 'babel-loader',
options: {
presets: ['@babel/preset-env'], // 预设,转换js语法
"plugins": [
["@babel/plugin-proposal-decorators", { "legacy": true }], // 解析类的装饰器
["@babel/plugin-proposal-class-properties", { "loose": true }], // 解析类的属性
"@babel/plugin-transform-runtime", // 解析promise,Generator等新的API
"@babel/polyfill" // 解析实例上的方法
]
}
},
include: path.resolve(__dirname, 'src'),
exclude: /node_modules/
}
expose-loader
npm install jquery
npm install expose-loader -D
- 在模块中,使用内联loader,完成向全局暴露一个变量
import $ from 'expose-loader?$!jquery'
console.log(window.$) // 打开浏览器,打印成功
- 通过webpack配置模块规则,向每个引入jquery的模块中注入全局变量
import $ from 'jquery'
// webpack.config.js
module: {
rules: [{
test: require.resolve('jquery'),
use: 'expose-loader?$'
}
}
- 其他暴露变量的方法:ProvidePlugin(内置):提供插件 — 可以用来向每个模块注入变量,但
不能
通过通过window.$来访问,并未暴露给全局,仅在每个模块中使用
// webpack.config.js
const webpack = require('webpack');
module: {
// ...
plugins: [
new webpack.ProvidePlugin({
$:'jquery'
}),
],
}
- cdn引入,但不打包
<-- index.html -->
<script src="http://code.jquery.com/jquery-migrate-1.2.1.min.js"></script>
// index.js
// 此时在文件中,可以拿到 $ 对象
// 但是如果再次通过 import 引入jquery,就会被重复打包,使打包后的文件,体积变大
import $ from 'jquery'
// webpack.config.js
module: {
// ...
externals: { // 分别对比配置该属性前后,打包后文件的体积,明显变小
jQuery: '$'
},
}
webpack4.15.1 学习笔记(十) — 常见 loader 使用的更多相关文章
- SharpGL学习笔记(十) 常见的光源类型,创建光源
在OpenGL中,使用光源的特性组合,如颜色,位置,方向等等,可以创建多种不同类型的灯光. 常见的几种灯光类型有: 定向光源(directonal) 定位光源(positional) 衰减光源 聚光灯 ...
- go微服务框架kratos学习笔记十(熔断器)
目录 go微服务框架kratos学习笔记十(熔断器) 什么是熔断 熔断器逻辑 kratos Breaker kratos 熔断逻辑 kratos熔断器使用说明 bladmaster client br ...
- python3.4学习笔记(十四) 网络爬虫实例代码,抓取新浪爱彩双色球开奖数据实例
python3.4学习笔记(十四) 网络爬虫实例代码,抓取新浪爱彩双色球开奖数据实例 新浪爱彩双色球开奖数据URL:http://zst.aicai.com/ssq/openInfo/ 最终输出结果格 ...
- Learning ROS for Robotics Programming Second Edition学习笔记(十) indigo Gazebo rviz slam navigation
中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 moveit是书的最后一章,由于对机械臂完全不知,看不懂 ...
- python3.4学习笔记(十八) pycharm 安装使用、注册码、显示行号和字体大小等常用设置
python3.4学习笔记(十八) pycharm 安装使用.注册码.显示行号和字体大小等常用设置Download JetBrains Python IDE :: PyCharmhttp://www. ...
- python3.4学习笔记(十九) 同一台机器同时安装 python2.7 和 python3.4的解决方法
python3.4学习笔记(十九) 同一台机器同时安装 python2.7 和 python3.4的解决方法 同一台机器同时安装 python2.7 和 python3.4不会冲突.安装在不同目录,然 ...
- python3.4学习笔记(十六) windows下面安装easy_install和pip教程
python3.4学习笔记(十六) windows下面安装easy_install和pip教程 easy_install和pip都是用来下载安装Python一个公共资源库PyPI的相关资源包的 首先安 ...
- python3.4学习笔记(十五) 字符串操作(string替换、删除、截取、复制、连接、比较、查找、包含、大小写转换、分割等)
python3.4学习笔记(十五) 字符串操作(string替换.删除.截取.复制.连接.比较.查找.包含.大小写转换.分割等) python print 不换行(在后面加上,end=''),prin ...
- python3.4学习笔记(十二) python正则表达式的使用,使用pyspider匹配输出带.html结尾的URL
python3.4学习笔记(十二) python正则表达式的使用,使用pyspider匹配输出带.html结尾的URL实战例子:使用pyspider匹配输出带.html结尾的URL:@config(a ...
- python3.4学习笔记(十) 常用操作符,条件分支和循环实例
python3.4学习笔记(十) 常用操作符,条件分支和循环实例 #Pyhon常用操作符 c = d = 10 d /= 8 #3.x真正的除法 print(d) #1.25 c //= 8 #用两个 ...
随机推荐
- zabbix使用
安装部署6.0版本 获取仓库 https://www.zabbix.com/cn/download?zabbix=6.0&os_distribution=centos&os_versi ...
- js 数组按指定字段转map-list结构
js 数组按指定字段转map-list结构 背景介绍 在开发过程中经常会出现接口返回整个数组,我们需要将数组进行二次处理,如下格式按照不同功能模块(type)进行数据拆分 原始数据 const lis ...
- 什么是Base64算法
HTTP是超文本传输协议,所以HTTP协议中请求.相应都是以ASCII字符方式传输,如果要传输二进制需要经过BASE64或MIME等编码(因为HTTP协议pop3.smtp邮件协议都是针对文本的,而F ...
- Linux之命令提示符的颜色设置
1.临时设置 执行下面的命令: export PS1="[\[\e[34;1m\]\u@\[\e[0m\]\[\e[32;1m\]\H\[\e[0m\] \[\e[31;1m\]\w\[\e ...
- ajax跨域(跨源)方案之CORS
ajax跨域(跨源)方案:后端授权[CORS],jsonp,服务端代理 CORS是一个W3C标准,全称是"跨域资源共享",它允许浏览器向跨源的后端服务器发出ajax请求,从而克服了 ...
- HTML——结构和标签格式
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 使用EntityFramework Core和Enums作为字符串的ASP.NET Core Razor页面——第三部分
目录 介绍 使用代码 添加项目和项目状态处理 下载源文件 - 989.1 KB 介绍 这是一篇由多部分组成的文章的第三部分,演示了通过EntityFramework Core 2.1(EF)将C#en ...
- ubuntu18.04开机grub引导界面、登录界面美化
1.引导界面美化 下载grub主题 https://www.gnome-look.org/browse/cat/109/order/latest/ https://www.pling.com/s/Gn ...
- Python实现求多个集合之间的并集-方法2
之前使用过一种方法实现求集合间的并集,参考文章:https://www.cnblogs.com/mrlayfolk/p/12373532.html,这次使用另外一种方法实现,这种方法效率更高. 目的: ...
- DS Record
八云蓝自动机 Ⅰ 首先我们对于操作 \(1\) 转换,我们给 \(k\) 单独再开一个点 \(a_c\),这样我们就可以把操作 \(1\) 转换成操作 \(2\) 了. 对于区间问题,我们考虑使用莫队 ...