Webpack處理樣式資源的配置詳情
Webpack 本身是不能識(shí)別樣式資源的,所以我們需要借助 Loader 來(lái)幫助 Webpack 解析樣式資源。我們本節(jié)就是要講述Webpack中如何處理CSS樣式資源。
CSS資源的處理
1.下載對(duì)應(yīng)的Loader
npm i css-loader style-loader -D
`css-loader`:負(fù)責(zé)將 Css 文件編譯成 Webpack 能識(shí)別的模塊,也就是將css文件轉(zhuǎn)化為符合commonJs語(yǔ)法的js文件
`style-loader`:會(huì)動(dòng)態(tài)創(chuàng)建一個(gè) Style 標(biāo)簽添加到html頁(yè)面上,里面放置 Webpack 中 Css 模塊內(nèi)容,此時(shí)樣式就會(huì)以 Style 標(biāo)簽的形式在頁(yè)面上生效
2.具體配置
const path = require("path");
module.exports = {
entry: "./src/main.js",
output: {
path: path.resolve(__dirname, "dist"),
filename: "main.js",
},
module: {
rules: [
{
// 用來(lái)匹配 .css 結(jié)尾的文件
test: /\.css$/,
// use 數(shù)組里面 Loader 執(zhí)行順序是從右到左
use: ["style-loader", "css-loader"],
},
],
},
plugins: [],
mode: "development",
};3.具體使用
例如我們使用如下代碼走一個(gè)完整的流程
- src/css/index.css
###
css
.box1 {
width: 100px;
height: 100px;
background-color: pink;
}
###
- src/main.js
###
js
import count from "./js/count";
import sum from "./js/sum";
// 引入 Css 資源,Webpack才會(huì)對(duì)其打包
import "./css/index.css";
console.log(count(2, 1));
console.log(sum(1, 2, 3, 4));
###
- public/index.html
###
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>webpack5</title>
</head>
<body>
<h1>Hello Webpack5</h1>
<!-- 準(zhǔn)備一個(gè)使用樣式的 DOM 容器 -->
<div class="box1"></div>
<!-- 引入打包后的js文件,才能看到效果 -->
<script src="../dist/main.js"></script>
</body>
</html>
###
有了如上代碼文件后,我們運(yùn)行以下指令:
npx webpack
然后就可以打開(kāi) index.html 頁(yè)面查看效果
less資源的處理
1.下載對(duì)應(yīng)的Loader
npm i less-loader -D
`less-loader`:負(fù)責(zé)將 Less 文件編譯成 Css 文件
2.具體配置
const path = require("path");
module.exports = {
entry: "./src/main.js",
output: {
path: path.resolve(__dirname, "dist"),
filename: "main.js",
},
module: {
rules: [
{
// 用來(lái)匹配 .css 結(jié)尾的文件
test: /\.css$/,
// use 數(shù)組里面 Loader 執(zhí)行順序是從右到左
use: ["style-loader", "css-loader"],
},
{
test: /\.less$/,
use: ["style-loader", "css-loader", "less-loader"],
},
],
},
plugins: [],
mode: "development",
};3.如何使用
和上述CSS文件的處理運(yùn)行方式一樣,只需要寫(xiě)好對(duì)應(yīng)的Less資源、html資源等,然后執(zhí)行如下指令,再打開(kāi)index.html查看效果即可
處理 Sass 和 Scss 資源
1.下載對(duì)應(yīng)的Loader
npm i sass-loader sass -D
-`sass-loader`:負(fù)責(zé)將 Sass 文件編譯成 css 文件
`sass`:`sass-loader` 依賴(lài) `sass` 進(jìn)行編譯
2.具體配置
const path = require("path");
module.exports = {
entry: "./src/main.js",
output: {
path: path.resolve(__dirname, "dist"),
filename: "main.js",
},
module: {
rules: [
{
// 用來(lái)匹配 .css 結(jié)尾的文件
test: /\.css$/,
// use 數(shù)組里面 Loader 執(zhí)行順序是從右到左
use: ["style-loader", "css-loader"],
},
{
test: /\.less$/,
use: ["style-loader", "css-loader", "less-loader"],
},
{
test: /\.s[ac]ss$/,
use: ["style-loader", "css-loader", "sass-loader"],
},
],
},
plugins: [],
mode: "development",
};具體使用和CSS、Less使用方式相同,只需寫(xiě)出對(duì)應(yīng)資源運(yùn)行 npx webpack 命令即可。
到此這篇關(guān)于Webpack處理樣式資源的配置詳情的文章就介紹到這了,更多相關(guān)Webpack 樣式資源內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue3與webpack5安裝element-plus樣式webpack編譯報(bào)錯(cuò)問(wèn)題解決
- vue+webpack dev本地調(diào)試全局樣式引用失效的解決方案
- webpack實(shí)現(xiàn)一個(gè)行內(nèi)樣式px轉(zhuǎn)vw的loader示例
- 詳解react內(nèi)聯(lián)樣式使用webpack將px轉(zhuǎn)rem
- webpack 樣式加載的實(shí)現(xiàn)原理
- 淺談webpack對(duì)樣式的處理
- webpack處理 css\less\sass 樣式的方法
- 詳解windows下vue-cli及webpack 構(gòu)建網(wǎng)站(二)導(dǎo)入bootstrap樣式
相關(guān)文章
詳解javascript立即執(zhí)行函數(shù)表達(dá)式IIFE
本文主要介紹了javascript立即執(zhí)行函數(shù)表達(dá)式IIFE的相關(guān)知識(shí)。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-02-02
原型方法的不同寫(xiě)法居然會(huì)影響調(diào)試的解決方法
原型方法的不同寫(xiě)法居然會(huì)影響調(diào)試的解決方法...2007-03-03
PHP+jQuery+Ajax+Mysql如何實(shí)現(xiàn)發(fā)表心情功能
這篇文章通過(guò)php+jquery+ajax+mysql相結(jié)合,實(shí)現(xiàn)當(dāng)用戶(hù)瀏覽網(wǎng)站文章或者是論壇帖子后,想表達(dá)自己瀏覽后的心情,發(fā)表自己的感受,很多網(wǎng)站都提供了用戶(hù)發(fā)表心情的功能,通過(guò)此功能可以很直觀的分析文章或者是論壇對(duì)瀏覽者的用戶(hù)體驗(yàn)度2015-08-08
關(guān)于JSON與JSONP簡(jiǎn)單總結(jié)
JSON(JavaScript Object Notation) 是一種輕量級(jí)的數(shù)據(jù)交換格式。而JSONP(JSON with Padding)是資料格式 JSON 的一種“使用模式”。下面是小編總結(jié)的關(guān)于JSON與JSONP知識(shí),感興趣的朋友一起看下吧2016-08-08
JavaScript實(shí)現(xiàn)簡(jiǎn)單的計(jì)算器功能
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)單的計(jì)算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-03-03
微信公眾號(hào)開(kāi)發(fā) 實(shí)現(xiàn)點(diǎn)擊返回按鈕就返回到聊天界面
本文分享了微信公眾號(hào)開(kāi)發(fā)實(shí)現(xiàn)點(diǎn)擊返回按鈕就返回到聊天界面的示例代碼。需要的朋友一起來(lái)看下吧2016-12-12

