常用Loader
在这里对常用的Loader做一下总结,方便我们找到自己所需的Loader。
文件处理相关
- file-loader(https://www.npmjs.com/package/file-loader):转换webpack不能识别的文件,代码中可以是使用相对URL去引用文件。
- url-loader
(https://www.npmjs.com/package/url-loader):功能和file-loader类似,唯一的区别是在文件很小的时候,以base64的方式将文件注入到代码中。 - raw-loader(https://www.npmjs.com/package/raw-loader):将文本文件的内容注入到代码中。
- source-map-loader(https://www.npmjs.com/package/source-map-loader):加载额外的SourceMap文件,方便调试
- svg-inline-loader(https://www.npmjs.com/package/svg-inline-loader):将压缩的SVG注入到代码中。
- image-loader(https://www.npmjs.com/package/image-loader):加载并压缩图片文件。
- yaml-loader(https://www.npmjs.com/package/yaml-loader):加载YAML文件。
- json-loader(https://www.npmjs.com/package/json-loader):加载JSON文件。
样式处理相关
- style-loader(https://www.npmjs.com/package/style-loader):将css代码加载到Javascript中,通过DOM操作去加载css。
- css-loader(https://www.npmjs.com/package/css-loader):加载css,支持模块化,压缩,文件导入等特性。
- less-loader(https://www.npmjs.com/package/less-loader):将Less代码转换成css代码。
- sass-loader(https://www.npmjs.com/package/sass-loader):将SASS/SCSS代码转换成css代码。
- stylus-loader(https://www.npmjs.com/package/stylus-loader):将Stylus代码转换成css代码。
- postcss-loader(https://www.npmjs.com/package/postcss-loader):扩展css,使用下一代css语法。
脚本语言处理相关
- babel-loader(https://www.npmjs.com/package/babel-loader):将ES6转换成ES5。
- ts-loader(https://www.npmjs.com/package/ts-loader):将TypeScript转换成JavaScript。
- awesome-typescript-loader(https://www.npmjs.com/package/awesome-typescript-loader):将TypeScript转换成JavaScript,性能比ts-loader好。
检查代码相关
- eslint-loader(https://www.npmjs.com/package/eslint-loader):使用Eslint检查JavaScript代码。
- tslint-loader(https://www.npmjs.com/package/tslint-loader):使用Tslint检查TypeScript代码。
- mocha-loader(https://www.npmjs.com/package/mocha-loader):加载Mocha测试用例的代码。
其他Loader
- cache-loader(https://www.npmjs.com/package/cache-loader):缓存相关loader的处理结果,例如babel-loader,下次构建加速。
- i18n-loader(https://www.npmjs.com/package/i18n-loader):加载多语言版本,支持国际化。
- vue-loader(https://www.npmjs.com/package/vue-loader):用于解析加载.vue文件。
- thread-loader(https://www.npmjs.com/package/thread-loader):使用worker pool加速相关loader的处理,比如babel-loader。