一、什么是loader

loader 用于对模块的源代码进行转换。loader 可以使你在 import 或"加载"模块时预处理文件。因此,loader 类似于其他构建工具中“任务(task)”,并提供了处理前端构建步骤的强大方法。loader 可以将文件从不同的语言(如 TypeScript)转换为 JavaScript,或将内联图像转换为 data URL。loader 甚至允许你直接在 JavaScript 模块中 import CSS文件!

二、怎么使用loader

示例:加载一个less-loader

1、首先使用npm命令安装less-loader

npm install --save-dev css-loader

2、loader使用

loader有三种方式可以引入到你的程序中

(1)Configuration(配置方式):推荐使用配置方式,在你的webpack.config.js 中配置进去

{
test: /\.less$/,
use: [{
loader: "style-loader" // creates style nodes from JS strings
}, {
loader: "css-loader" // translates CSS into CommonJS
}, {
loader: "less-loader" // compiles Less to CSS
}]
},

(2)inline(内联方式引入):通过使用import方式引入

import Styles from 'style-loader!less-loader?modules!./styles.less';

(3)cli(命令行方式引入):可以使用命令的形式引入(不推荐,太麻烦)

webpack --module-bind jade-loader --module-bind 'css=style-loader!css-loader'

 三、loaders的分类(具体用法请参考官网https://doc.webpack-china.org/loaders

文件

  • raw-loader 加载文件原始内容(utf-8)

  • val-loader 将代码作为模块执行,并将 exports 转为 JS 代码

  • url-loader 像 file loader 一样工作,但如果文件小于限制,可以返回 data URL

  • file-loader 将文件发送到输出文件夹,并返回(相对)URL

JSON

  • json-loader 加载 JSON 文件(默认包含)
  • json5-loader 加载和转译 JSON 5 文件
  • cson-loader 加载和转译 CSON 文件

转换编译(Transpiling)

  • script-loader 在全局上下文中执行一次 JavaScript 文件(如在 script 标签),不需要解析
  • babel-loader 加载 ES2015+ 代码,然后使用 Babel 转译为 ES5
  • buble-loader 使用 Bublé 加载 ES2015+ 代码,并且将代码转译为 ES5
  • traceur-loader 加载 ES2015+ 代码,然后使用 Traceur 转译为 ES5
  • ts-loader 或 awesome-typescript-loader 像 JavaScript 一样加载 TypeScript 2.0+
  • coffee-loader 像 JavaScript 一样加载 CoffeeScript

模板(Templating)

  • html-loader 导出 HTML 为字符串,需要引用静态资源
  • pug-loader 加载 Pug 模板并返回一个函数
  • jade-loader 加载 Jade 模板并返回一个函数
  • markdown-loader 将 Markdown 转译为 HTML
  • react-markdown-loader 使用 markdown-parse parser(解析器) 将 Markdown 编译为 React 组件
  • posthtml-loader 使用 PostHTML 加载并转换 HTML 文件
  • handlebars-loader 将 Handlebars 转移为 HTML
  • markup-inline-loader 将内联的 SVG/MathML 文件转换为 HTML。在应用于图标字体,或将 CSS 动画应用于 SVG 时非常有用。

样式

  • style-loader 将模块的导出作为样式添加到 DOM 中
  • css-loader 解析 CSS 文件后,使用 import 加载,并且返回 CSS 代码
  • less-loader 加载和转译 LESS 文件
  • sass-loader 加载和转译 SASS/SCSS 文件
  • postcss-loader 使用 PostCSS 加载和转译 CSS/SSS 文件
  • stylus-loader 加载和转译 Stylus 文件

清理和测试(Linting && Testing)

  • mocha-loader 使用 mocha 测试(浏览器/NodeJS)
  • eslint-loader PreLoader,使用 ESLint 清理代码
  • jshint-loader PreLoader,使用 JSHint 清理代码
  • jscs-loader PreLoader,使用 JSCS 检查代码样式
  • coverjs-loader PreLoader,使用 CoverJS 确定测试覆盖率

框架(Frameworks)

  • vue-loader 加载和转译 Vue 组件
  • polymer-loader 使用选择预处理器(preprocessor)处理,并且 require() 类似一等模块(first-class)的 Web 组件
  • angular2-template-loader 加载和转译 Angular 组件

最新文章

  1. salesforce 零基础学习(五十三)多个文件生成一个zip文件(使用git上封装的代码)
  2. UML之类图
  3. Android 升级SQLite数据库
  4. Redis-cluster集群【第三篇】:redis主从
  5. 【iCore3双核心板】iCore3双核心板使用说明(图文)
  6. 水题 ZOJ 3876 May Day Holiday
  7. PHP 获取网上文件内容
  8. https://github.com/oneuijs/You-Dont-Need-jQuery
  9. ruby关于flip-flop理解上一个注意点
  10. c#中@符号作用
  11. web开发学习之旅---html第一天
  12. ASP.Net MVC-Web API使用Entity Framework时遇到Loop Reference
  13. c#引用web.config中的ConnectionString
  14. ViEmu For VS2010 3.0 解除30天限制的方法
  15. 从计算机语言的发展到我的第一行代码(HelloWorld)
  16. [python学习笔记] py2exe 打包
  17. Springboot 拦截器的背后
  18. HTML之 一 标签
  19. pip更新到18版本后使用pycharm更新问题:module 'pip' has no attribute 'main'
  20. [SDOI2010]古代猪文 (欧拉,卢卡斯,中国剩余)

热门文章

  1. java 双重校验性volatile
  2. 工厂方法配置bean
  3. C#排列组合类,写彩票算法的朋友们可以来看一看
  4. MFC对话框编程详细学习笔记
  5. python之绘制函数pyplot初探
  6. Unicode数据类型的是是非非(转)
  7. django 里面的更新数据(update)
  8. OO七大设计原则
  9. 使用jmeter做接口测试----柠檬不萌!
  10. Haproxy+Percona-XtraDB-Cluster 集群