用于在js中加载css,解释@import
和url()
css
alias
: 解析别名importLoaders(@import)
: 在css-loader前应用的loader的数目,默认为0Minimize
: true
or false
是否开启css代码压缩,好比压缩空格不换行modules
: 是否开启css-module
html
module.exports = { ... module: { rules: [{ test: /\.css$/, use: ['style-loader', { loader: 'css-loader', options: {//当css文件中又引用了其余的css的时候,须要设置importLoaders importLoaders: 1 } }] }] } };
加载的css做为style标签内容插入到html中,以<style></style>
形式在html页面中插入css代码webpack
insertAt
: 插入位置insertInto
: 插入到指定的domsingleton
: true or false,多个样式是否只生成一个<style></style>
标签web
postcss-loader
:为了浏览器的兼容性,有时候咱们必须加上-webkitm
, -ms
, -moz
等前缀。目的就是让页面能够在每一个浏览器上正常运行。postcss是一个CSS的处理平台能够帮CSS实现更多的功能。
用法:
安装postcss
: npm install postcss-loader autoprefixer
配置文件npm
webpack.config.js: module: { rules: [{ test: /\.css$/ loader: 'style-loader!css-loader!postcss-loader' }] } postcss.config.js module.exports = { plugins: [ require('autoprefixer')//在postcss-loader中引入autoprefixer插件 ] }
或者浏览器
const autoprefixer = require('autoprefixer'); module: { rules: [{ test: /\.css$/, use: ['style-loader', 'css-loader', { loader: 'postcss-loader', options: { plugins() { return [autoprefixer]; } } }] }] }
添加对webpack的LESS支持。当遇到less文件时,先交给less-loader处理,而后交给css-loader,最后交由style-loader处理,而后执行webpack打包less
module: { rules: [{ test: /\.less$/, loader: 'style-loader!css-loader!less-loader' }] }
要启用CSS的source map,你须要将sourceMap
选项传递给less-loader
和css-loader
dom
CSS SourceMap
信息文件,里面存储着位置信息。随着代码增多,咱们会对代码进行压缩,代码压缩以后进行调bug定位会很是困难,因而引入sourceMap
记录压缩先后的位置信息,当产生错误时直接定位到未压缩前的位置,方便调试。简单来讲就是记录压缩的翻译文件,经过这个文件能够找到你的对应源码post
module.exports = { ... module: { rules: [{ test: /\.less$/, use: ['style-loader', 'css-loader', { loader: 'less-loader', options: { sourceMap: true } }] }] } };
less-loader
可用的options
:modifyVars
或 globalVars
声明全局变量: {Object}
,在less
使用全局变量时,咱们能够定义一个全局变量的文件,而后每次使用时都引用这个文件,显而易见,这个方法很麻烦。less
还提供了另外的方法来声明全局变量,即在options.globalVars/options.modifyVars
里进行配置。ui
modifyVars
修改全局的less变量,globalVars
声明全局的less变量
module.exports = { ... module: { test: /\.less$/, use: [ 'style-loader', 'css-loader, { loader: 'less-loader', options: { midifyVars: { @bgColor: red; //或者bgColor: red,有没有@均可以 } /*globalVars: { @bgColor: red; }*/ } } ] } };
body { background-color: @bgColor;//使用时必须有@ }
编译后
body { background-color: red; }