首先亮出webpack官方網站,webpack能幹什麼?官網給出的答案就是,一句話,讓一切變得簡單!css
各式各樣的loader層出不窮,讓咱們在構建時不知所措,於此,總結下loader的全解析。html
loader,顧名思義,加載器,英文的解釋以下:
Loaders are transformations that are applied on the source code of a module. They allow you to pre-process files as you import or 「load」 them. Thus, loaders are kind of like 「tasks」 in other build tools, and provide a powerful way to handle front-end build steps. Loaders can transform files from a different language (like TypeScript) to JavaScript, or inline images as data URLs. Loaders even allow you to do things like import CSS files directly from your JavaScript modules!
中文翻譯過來就是:
loader 用於對模塊的源代碼進行轉換。loader 可使你在 import 或「加載」模塊時預處理文件。所以,loader 相似於其餘構建工具中「任務(task)」,並提供了處理前端構建步驟的強大方法。loader 能夠將文件從不一樣的語言(如 TypeScript)轉換爲 JavaScript,或將內聯圖像轉換爲 data URL。loader 甚至容許你直接在 JavaScript 模塊中 import CSS文件!
從中,能夠看出loader的強大做用,分析下:前端
總結一句話:loader, 加載的機器,形象的比喻下,就像一個豆漿機,放上你的原料,它就開始認真的工做了!vue
在你的應用程序中,有三種使用 loader 的方式:node
module: {
rules: [
{
test: /\.css$/,
use: [
{ loader: 'style-loader' },
{
loader: 'css-loader',
options: {
modules: true
}
}
]
}
]
}複製代碼
import Styles from 'style-loader!css-loader?modules!./styles.css';複製代碼
經過前置全部規則及使用 !,能夠對應覆蓋到配置中的任意 loader。webpack --module-bind jade-loader --module-bind 'css=style-loader!css-loader'複製代碼
這會對 .jade 文件使用 jade-loader,對 .css 文件使用 style-loader 和 css-loader。loader 遵循標準的模塊解析。多數狀況下,loader 將從模塊路徑(一般將模塊路徑認爲是 npm install, node_modules)解析。webpack
loader 模塊須要導出爲一個函數,而且使用 Node.js 兼容的js編寫。一般使用 npm 進行管理,可是也能夠將自定義 loader 做爲應用程序中的文件。按照約定,loader 一般被命名爲 xxx-loader(例如 json-loader)。git
webpack 可使用 loader 來預處理文件。這容許你打包除js 以外的任何靜態資源。你可使用 Node.js 來很簡單地編寫本身的 loader。github
npm install --save-dev babel-loader babel-core babel-preset-env webpack
{
test: /\.js$/,
exclude: /node_modules/,
loader: 'babel-loader'
}複製代碼
Adds CSS to the DOM by injecting a <style> tag
npm install style-loader --save-dev
{
test: /\.css$/,
use: [
'style-loader',
'css-loader'
]
}複製代碼
npm install css-loader --save-dev
{
test: /\.css$/,
use: [ 'style-loader', 'css-loader' ]
}複製代碼
npm install --save-dev less-loader less
{
test: /\.less$/,
exclude: /node_modules/,
use: ExtractTextPlugin.extract(['css-loader', 'less-loader'])
}複製代碼
npm install --save-dev url-loader
{
test: /\.(jpg|jpeg|png|gif)$/,
loader: 'url-loader',
options: {
limit: 8192
}
}複製代碼
npm install file-loader --save-dev
{
test: /\.(woff|woff2|svg|eot|ttf)$/,
use: 'file-loader'
}複製代碼
npm install --save-dev vue-loader vue vue-template-compiler
{
test: /\.vue$/,
loader: 'vue-loader',
options: {
loaders: {
less: ExtractTextPlugin.extract({
use: ['css-loader', 'less-loader'],
fallback: 'vue-style-loader'
})
}
}
}複製代碼
npm i -D postcss-loader
{
test: /\.sss$/,
use: [
...,
{ loader: 'postcss-loader', options: { parser: 'sugarss' } }
]
}複製代碼
至此,有關loader中所用的參數請移步官網查詢解決,謝謝查閱!