欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

extract-text-webpack-plugin用法詳解

 更新時(shí)間:2019年02月14日 08:35:48   作者:畢聰聰  
這篇文章主要介紹了extract-text-webpack-plugin用法詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

一 背景

最近在做一個(gè)項(xiàng)目,項(xiàng)目本身是用vue-cli創(chuàng)建的單頁(yè)面應(yīng)用,由于項(xiàng)目擴(kuò)展需要?jiǎng)?chuàng)建多頁(yè)面,所以需要對(duì)不同的html分別進(jìn)行css文件打包。于是開(kāi)始研究extract-text-webpack-plugin插件。

二 插件介紹

打包樣式有兩種方法,一種是使用style-loader自動(dòng)將css代碼放到生成的style標(biāo)簽中,并且插入到head標(biāo)簽里。另一種就是使用extract-text-webpack-plugin插件,將樣式文件單獨(dú)打包,打包輸出的文件由配置文件中的output屬性指定。然后我們?cè)谌肟贖TML頁(yè)面寫個(gè)link標(biāo)簽引入這個(gè)打包后的樣式文件。

三 插件使用

1 插件安裝:

# for webpack 3 
npm install --save-dev extract-text-webpack-plugin
# for webpack 2 
npm install --save-dev extract-text-webpack-plugin@2.1.2
# for webpack 1 
npm install --save-dev extract-text-webpack-plugin@1.0.1

2 插件使用

在webpack.config.js中引入

const ExtractTextPlugin = require("extract-text-webpack-plugin");

module.exports = {
 module: {
 rules: [
  {
  test: /\.css$/,
  use: ExtractTextPlugin.extract({
   fallback: "style-loader", // 編譯后用什么loader來(lái)提取css文件
   use: "css-loader" // 指需要什么樣的loader去編譯文件,這里由于源文件是.css所以選擇css-loader
  })
  }
 ]
 },
 plugins: [
 new ExtractTextPlugin("styles.css"),
 ]
}

多實(shí)例

在實(shí)例上也有個(gè) extract function。如果你有1個(gè)以上的 ExtractTextPlugin 的實(shí)例,你應(yīng)該使用實(shí)例上的 extract。

const ExtractTextPlugin = require('extract-text-webpack-plugin');

// Create multiple instances
const extractCSS = new ExtractTextPlugin('stylesheets/[name]-one.css');
const extractLESS = new ExtractTextPlugin('stylesheets/[name]-two.css');

module.exports = {
 module: {
 rules: [
  {
  test: /\.css$/,
  use: extractCSS.extract([ 'css-loader', 'postcss-loader' ])
  },
  {
  test: /\.less$/i,
  use: extractLESS.extract([ 'css-loader', 'less-loader' ])
  },
 ]
 },
 plugins: [
 extractCSS,
 extractLESS
 ]
};

抽取 Less 或者 Sass

配置是相同的, 根據(jù)需求使用 sass-loader 取代 less-loader。

const ExtractTextPlugin = require('extract-text-webpack-plugin');

module.exports = {
 module: {
 rules: [
  {
  test: /\.scss$/,
  use: ExtractTextPlugin.extract({
   fallback: 'style-loader',
   use: ['css-loader', 'sass-loader']
  })
  }
 ]
 },
 plugins: [
 new ExtractTextPlugin('style.css')
 //if you want to pass in options, you can do so:
 //new ExtractTextPlugin({
 // filename: 'style.css'
 //})
 ]
}

url() Resolving

如果你運(yùn)行 webpack 發(fā)現(xiàn) urls resolve 不對(duì)。你可以使用 options 擴(kuò)展 loader 功能。 url: false 使得你的路徑 resolve 的時(shí)候不會(huì)發(fā)生任何變化。

const ExtractTextPlugin = require('extract-text-webpack-plugin');

module.exports = {
 module: {
 rules: [
  {
  test: /\.scss$/,
  use: ExtractTextPlugin.extract({
   fallback: 'style-loader',
   use: [
   {
    loader: 'css-loader',
    options: {
     // If you are having trouble with urls not resolving add this setting.
     // See https://github.com/webpack-contrib/css-loader#url
     url: false,
     minimize: true,
     sourceMap: true
    }
   }, 
   {
    loader: 'sass-loader',
    options: {
     sourceMap: true
    }
   }
   ]
  })
  }
 ]
 }
}

改變文件名

filename 參數(shù)可以是 Function。通過(guò)傳入 getPath 去處理像 css/[name].css 的格式,返回一個(gè)真正的文件名, css/js/a.css。你可以替換 css/js 為 css,這樣你可以得到一個(gè)新的路徑 css/a.css。

entry: {
 'js/a': "./a"
},
plugins: [
 new ExtractTextPlugin({
 filename: (getPath) => {
  return getPath('css/[name].css').replace('css/js', 'css');
 },
 allChunks: true
 })
]

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 一文帶你搞懂JS中六種For循環(huán)的使用

    一文帶你搞懂JS中六種For循環(huán)的使用

    for?循環(huán)是出現(xiàn)最早,也是應(yīng)用最普遍的一個(gè)遍歷,能夠滿足絕大多數(shù)的遍歷。可以遍歷?數(shù)組、對(duì)象、字符串。本文將詳細(xì)為大家介紹JS中的六種For循環(huán)的使用,需要的可以參考一下
    2022-04-04
  • 寫給小白看的JavaScript異步

    寫給小白看的JavaScript異步

    寫給小白看的JavaScript異步,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 開(kāi)源一個(gè)微信小程序儀表盤組件過(guò)程解析

    開(kāi)源一個(gè)微信小程序儀表盤組件過(guò)程解析

    這篇文章主要介紹了開(kāi)源一個(gè)微信小程序儀表盤組件過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • JS實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn)并傳值

    JS實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn)并傳值

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn)并傳值,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • 使用Xcache緩存器加速PHP網(wǎng)站的配置方法

    使用Xcache緩存器加速PHP網(wǎng)站的配置方法

    由于國(guó)內(nèi)網(wǎng)站備案比較麻煩,所以筆者便把網(wǎng)站放到了香港。雖然網(wǎng)站免去了備案的困擾,但是從訪問(wèn)速度上來(lái)看,一般要比放于國(guó)內(nèi)的網(wǎng)站慢2-3倍,所以便想辦法對(duì)網(wǎng)站做了一些簡(jiǎn)單的優(yōu)化,比如使用緩存系統(tǒng)來(lái)提升網(wǎng)站頁(yè)面訪問(wèn)速度
    2017-04-04
  • 詳解webpack-dev-middleware 源碼解讀

    詳解webpack-dev-middleware 源碼解讀

    這篇文章主要介紹了webpack-dev-middleware 源碼解讀,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • JavaScript字符串轉(zhuǎn)換數(shù)字的方法

    JavaScript字符串轉(zhuǎn)換數(shù)字的方法

    這篇文章主要介紹了JavaScript字符串轉(zhuǎn)換數(shù)字的方法,文章圍繞JavaScript字符串轉(zhuǎn)換數(shù)字的相關(guān)資料展開(kāi)全文內(nèi)容,需要的小伙伴可以參考一下
    2021-12-12
  • JS?可選鏈的三種形勢(shì)及好處詳解

    JS?可選鏈的三種形勢(shì)及好處詳解

    這篇文章主要為大家介紹了JS?可選鏈的三種形勢(shì)及好處詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • JS定時(shí)器使用,定時(shí)定點(diǎn),固定時(shí)刻,循環(huán)執(zhí)行詳解

    JS定時(shí)器使用,定時(shí)定點(diǎn),固定時(shí)刻,循環(huán)執(zhí)行詳解

    下面小編就為大家?guī)?lái)一篇JS定時(shí)器使用,定時(shí)定點(diǎn),固定時(shí)刻,循環(huán)執(zhí)行詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-05-05
  • JS實(shí)現(xiàn)從表格中動(dòng)態(tài)刪除指定行的方法

    JS實(shí)現(xiàn)從表格中動(dòng)態(tài)刪除指定行的方法

    這篇文章主要介紹了JS實(shí)現(xiàn)從表格中動(dòng)態(tài)刪除指定行的方法,通過(guò)getElementById獲取指定行再使用deleteRow方法來(lái)實(shí)現(xiàn)刪除行的功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-03-03

最新評(píng)論