对webpack的初步研究5
Loaders
加载器是应用于模块源代码的转换。它们允许您在处理import
或“加载” 文件时预处理文件。因此,加载器有点像其他构建工具中的“任务”,并提供了处理前端构建步骤的强大方法。加载器可以将文件从不同的语言(如TypeScript)转换为JavaScript或内联图像作为数据URL。加载器甚至允许您import
直接从JavaScript模块执行CSS文件等操作!
例如,您可以使用加载器告诉webpack加载CSS文件或将TypeScript转换为JavaScript。要做到这一点,您首先要安装所需的加载器:
npm install --save-dev css-loader
npm install --save-dev ts-loader
然后指示webpack使用css-loader
for each .css
文件和ts-loader
所有.ts
文件:
webpack.config.js
module.exports = {
module: {
rules: [
{ test: /\.css$/, use: 'css-loader' },
{ test: /\.ts$/, use: 'ts-loader' }
]
}
};
module.rules
允许您在webpack配置中指定多个加载器。这是显示加载器的简洁方法,有助于维护干净的代码。它还为您提供每个相应装载机的完整概述。
从右到左评估/执行装载程序。在下面的示例中,执行从sass-loader开始,继续使用css-loader,最后以style-loader结束。有关装载机订单的更多信息,请参阅“装载机功能”。
module.exports = {
module: {
rules: [
{
test: /\.css$/,
use: [
{ loader: 'style-loader' },
{
loader: 'css-loader',
options: {
modules: true
}
},
{ loader: 'sass-loader' }
]
}
]
}
};
可以在import
语句中指定加载器,或任何等效的“导入”方法。将资源与资源分开!
。每个部分都相对于当前目录进行解析。
import Styles from 'style-loader!css-loader?modules!./styles.css';
可以通过为整个规则添加前缀来覆盖配置中的任何加载器!
。
可以使用查询参数(例如?key=value&foo=bar
,或JSON对象)传递选项,例如?{"key":"value","foo":"bar"}
。
module.rules
尽可能使用,因为这将减少源代码中的样板,并允许您在出现问题时更快地调试或定位加载程序。
您还可以通过CLI使用加载器:
webpack --module-bind jade-loader --module-bind 'css=style-loader!css-loader'
这使用jade-loader
的.jade
文件,以及style-loader
和css-loader
对.css
文件。
解决装载机
装载机遵循标准模块分辨率。在大多数情况下,它会从被载入模块路径(想想npm install
,node_modules
)。
加载器模块应该导出一个函数并用Node.js兼容的JavaScript编写。它们通常使用npm进行管理,但您也可以将自定义加载器作为应用程序中的文件。按照惯例,装载机通常被命名xxx-loader
(例如json-loader
)。请参阅“如何编写加载程序?”了解更多信息。
对webpack的初步研究5的更多相关文章
- 对webpack的初步研究8
模块 编辑文档 在模块化编程中,开发人员将程序分解为称为模块的离散功能块. 每个模块的表面积小于完整程序,使验证,调试和测试变得微不足道.编写良好的模块提供了可靠的抽象和封装边界,因此每个模块在整个应 ...
- 对webpack的初步研究7
Configuration 您可能已经注意到很少有webpack配置看起来完全相同.这是因为webpack的配置文件是导出对象的JavaScript文件.然后,webpack根据其定义的属性处理此对象 ...
- 对webpack的初步研究6
Plugins 插件是webpack 的支柱.webpack本身构建在您在webpack配置中使用的相同插件系统上! 它们也是这样做的目的别的,一个装载机无法做到的. Anatomy webpack ...
- 对webpack的初步研究4
Mode string module.exports = { mode: 'production' }; webpack --mode=production The following string ...
- 对webpack的初步研究3
Output配置output配置选项告诉webpack如何将编译后的文件写入磁盘.请注意,虽然可以有多个entry点,但只output指定了一个配置. A filename to use for th ...
- 对webpack的初步研究2
Entry Points 如“ 入门”中所述,有多种方法可以entry在webpack配置中定义属性.我们会告诉你,你的方法可以配置的entry属性,除了解释为什么它可能对你有用 Single Ent ...
- 对webpack的初步研究1
一.概念: 1.webpack的核心是用于现代JavaScript应用程序的静态模块捆绑器.当webpack处理您的应用程序时,它会在内部构建一个依赖关系图,它映射您的项目所需的每个模块并生成一个或多 ...
- iOS多线程的初步研究(六)
iOS多线程的初步研究(六) iOS平台提供更高级的并发(异步)调用接口,让你可以集中精力去设计需完成的任务代码,避免去写与程序逻辑无关的线程生成.运行等管理代码.当然实质上是这些接口隐含生成线程和管 ...
- iOS多线程的初步研究3
iOS多线程的初步研究(三) 弄清楚NSRunLoop确实需要花时间,这个类的概念和模式似乎是Apple的平台独有(iOS+MacOSX),很难彻底搞懂(iOS没开源,呜呜). 官网的解释是说run ...
随机推荐
- Django学习之数据库与ORM
二.ORM表模型 表(模型)的创建: 1.ORM之增(create.save) 一对多(ForeignKey): 多对多(ManyToManyField()): 2.ORM之删(delete) 3.O ...
- Java-小技巧-006 List 排序 Collections.sort()
一.数组操作类:Arrays 最早开始使用,查看方法二分查找:public static int binarySearch(数据类型[] a, 数据类型 key) 前提是有序的 equals 先排序 ...
- github.com/oschwald/maxminddb-golang 安装报错
安装 maxminddb-golang错误: dill@ubuntu-vm:~/workspace/go/src/github.com$ go get github.com/oschwald/maxm ...
- protel封装总结(新手必看)
零件封装是指实际零件焊接到电路板时所指示的外观和焊点的位置.是纯粹的空间概念.因此不同的元件可共用同一零件封装,同种元件也可有不同的零件封装.像电阻,有传统的针插式,这种元件体积较大,电路板必须钻孔才 ...
- Mysql 免安装版本配置
1. 安装命令 (制定安装目录的my.ini文件) mysqld --install MySQL --defaults-file="C:\mysql-5.7.26-winx64\bin\my ...
- ABI与API的区别
ABI是定义二进制级别的,两个模块的接口 比如一个二进制模块想要调用另外一个二进制模块提供的功能,它需要知道怎样通过汇编语言(即机器指令)去调用,以及怎样传递相应的参数和返回值(通过寄存器还是栈内存, ...
- linux中cut命令
cut命令 cut常用参数 cut命令用来显示行中的指定部分,删除文件中指定字段. 说明:该命令有两项功能,其一是用来显示文件的内容,它依次读取由参数file所指明的文件,将它们的内容输出到标准输出上 ...
- Codeforces Round #503 (by SIS, Div. 2) C. Elections (暴力+贪心)
[题目描述] Elections are coming. You know the number of voters and the number of parties — n and m respe ...
- CSS固定定位实现右下角可关闭广告
代码: <!DOCTYPE html><html lang="zh-cn"><head> <meta charset="UTF- ...
- $_ENV输出为null的原因及解决办法
有些朋友输出$_ENV是空的,可能原因是php.ini的variables_order值为"GPCS",也就是说系统在定义PHP预定义变量时的顺序是GET,POST,COOKIES ...