比如说下面的Loader写法:
style-loader!css-loader!sass-loader
我们一般都是习惯从左往右,为什么Loader的写法是从右往左呢?
比如说下面的Loader写法:
style-loader!css-loader!sass-loader
我们一般都是习惯从左往右,为什么Loader的写法是从右往左呢?
6 回答5.3k 阅读✓ 已解决
9 回答9.5k 阅读
5 回答3.8k 阅读✓ 已解决
5 回答8.1k 阅读✓ 已解决
4 回答8.1k 阅读✓ 已解决
7 回答10.1k 阅读
5 回答7.8k 阅读
感谢zvit指出之前的答案问题。
其实为啥是从右往左,而不从左往右,只是Webpack选择了compose方式,而不是pipe的方式而已,在技术上实现从左往右也不会有难度
在Uninx有pipeline的概念,平时应该也有接触,比如
ps aux | grep node
,这些都是从左往右的。但是在函数式编程中有组合的概念,我们数学中常见的
f(g(x))
,在函数式编程一般的实现方式是从右往左,如这里可以看到我们先执行的加1,然后执行的double,在compose中是采用reduceRight,所以我们传入参数的顺序编程了先传入double,后传入add1
那么其实也可以实现从左往右
所以只不过webpack选择了函数式编程的方式,所以loader的顺序编程了从右往左,如果webpack选择了pipe的方式,那么大家现在写loader的时候的顺序就变成从左往右了
compose :
require("style-loader!css-loader!sass-loader!./my-styles.sass");
pipe :
require("./my-styles.sass!sass-loader!css-loader!style-loader");
===================== 分隔线 之前的答案 =========================
less-loader 是将less文件编译成css
sass-loader 是将sass文件编译成css
css-loader 是处理css文件中的url()等
style-loader 将css插入到页面的style标签顺便告诉你