用於在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; }