溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

webpack css加載和圖片加載實例分析

發(fā)布時間:2022-04-28 16:16:38 來源:億速云 閱讀:112 作者:iii 欄目:大數據

這篇文章主要介紹“webpack css加載和圖片加載實例分析”,在日常操作中,相信很多人在webpack css加載和圖片加載實例分析問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”webpack css加載和圖片加載實例分析”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

css加載器

在webpack中,所有的資源(js文件、css文件、模板文件,圖片文件等等)都被看成是一個模塊,因此多有的資源都是可以被加載的。

加載這些資源我們要在module屬性定義這些加載配置(指定加載器)。

在module屬性中,通過定義loaders定義加載器,其屬性值是一個數組,每一個成員代表一個配置。

  • 通過test定義匹配的規(guī)則(正則表達式)

  • 通過loader定義加載器,可以通過!級聯多個加載器

加載css是要兩個加載器,一個是style-loader,一個是css-loader樣式文件默認加載到head里面。

我們來看一個小例子

|__static 
??|__css 
????|__app.css 
??|__app.js 
|__ index.html 
|__webpack.config.js

app.css

h2{
  background:red;
  width:100px;
  height:100px;
  color:blue;
}

app.js

require('./css/app.css')
document.write('<h2>hello connie</h2>')

index.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>
<body>
<script type="text/javascript" src="dest/dest.js"></script>
</body>
</html>

webpack.config.js

module.exports = {
  entry:'./static/app.js',
  output:{
    filename:'dest/dest.js'
  },
  module:{
    loaders:[
      {
        // 配置正則表達式,查找后綴為.css文件
        test:/\.css$/,
        // 配置加載器,用!符號級聯
        loader:'style-loader!css-loader'
      }
    ]
  }
}

注意:test參數是正則表達式,不需要加引號,如果寫成test:“/.css$/”會報錯?。?!

圖片加載器

在webpack,圖片資源也可以被看成是一個模塊,因此也可以用require去加載它們。

但是加載這些圖片,我們需要圖片加載器,圖片加載器叫url-loader

圖片加載比較特殊,有兩種加載方式

  • 內嵌式:將圖片嵌入文件內部(圖片將轉換成base64格式)

  • 外鏈式,將圖片作為一個資源嵌入(通過圖片路徑引入)

在webpack中,我們可以在url-loader中定義個limit參數,來決定采取哪種方式引入。

  • 語法 url-loader?limit=2048

  • ?是用來定義加載器的參數配置的

  • Limit表示圖片大小限制

  • 2048單位是b,所以2048表示2Kb

這句話的意思是,當圖片小于2KB的時候,我們采取內嵌式加載圖片

當圖片大于2kb的時候我們采取外鏈式。

app.css

div{
  height: 200px;
  width: 200px;
}

.test1{
  background-image: url("./images/test1.png");
}

.test2{
  background-image: url("./images/test2.jpg");
}

.test3{
  background-image: url("./images/test3.png");
}

webpack.config.js

module.exports = {
  entry: './static/app.js',
  output: {
    filename: 'dest/dest.js'
  },
  module: {
    loaders:[
      {
        // 圖片加載器
        test:/\.(png|jpg|gif|jpeg)$/,
        loader:'url-loader?limit=2048'
      },
      {
        test:/\.css$/,
        loader:'style-loader!css-loader'
      }
    ]
  }
}

圖片加載需要安裝url-loader和file-loader

npm install url-loader
npm install file-loader

再次查看dest.js

webpack css加載和圖片加載實例分析

到此,關于“webpack css加載和圖片加載實例分析”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注億速云網站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI