摘要:教程所示圖片使用的是倉庫圖片,網速過慢的朋友請移步原文系列教程七提取和懶加載。個人技術小站有空就來看看我一直都在本節課講解在中的提取和懶加載。值得一提的是,和在的懶加載上的處理方法有著巨大差別。
教程所示圖片使用的是 github 倉庫圖片,網速過慢的朋友請移步>>> (原文)webpack4 系列教程(七): SCSS 提取和懶加載。
個人技術小站: https://godbmw.com 有空就來看看, 我一直都在
本節課講解在webpack v4中的 SCSS 提取和懶加載。值得一提的是,v4和v3在 Scss 的懶加載上的處理方法有著巨大差別。
>>> 本節課源碼
>>> 所有課程源碼
1. 準備工作關于 SCSS 處理的基礎,請參考webpack4 系列教程(六): 處理 SCSS。
本節課主要涉及 SCSS 在懶加載下提取的相關配置和插件使用。
下圖展示了這次的目錄代碼結構:
為了實現 SCSS 懶加載,我們使用了extract-text-webpack-plugin插件。
需要注意,在安裝插件的時候,應該安裝針對v4版本的extract-text-webpack-plugin。npm 運行如下命令:npm install --save-dev extract-text-webpack-plugin@next
其余配置,與第六課相似。package.json配置如下:
{ "devDependencies": { "css-loader": "^1.0.0", "extract-text-webpack-plugin": "^4.0.0-beta.0", "node-sass": "^4.9.2", "sass-loader": "^7.0.3", "style-loader": "^0.21.0", "webpack": "^4.16.0" } }
關于我們的 scss 文件下的樣式文件,base.scss:
// 網站默認背景色:red $bgColor: red !default; *, body { margin: 0; padding: 0; } html { background-color: $bgColor; }
common.scss:
// 覆蓋原來顏色:green html { background-color: green !important; }2. 使用ExtractTextPlugin
使用extract-text-webpack-plugin,需要在webpack.config.js的plugins選項和rules中scss的相關選項進行配置。
webpack.config.js:
const path = require("path"); const ExtractTextPlugin = require("extract-text-webpack-plugin"); module.exports = { entry: { app: "./src/app.js" }, output: { publicPath: __dirname + "/dist/", path: path.resolve(__dirname, "dist"), filename: "[name].bundle.js", chunkFilename: "[name].chunk.js" }, module: { rules: [ { test: /.scss$/, use: ExtractTextPlugin.extract({ // 注意 1 fallback: { loader: "style-loader" }, use: [ { loader: "css-loader", options: { minimize: true } }, { loader: "sass-loader" } ] }) } ] }, plugins: [ new ExtractTextPlugin({ filename: "[name].min.css", allChunks: false // 注意 2 }) ] };
在配置中,注意 1中的callback配置項,針對 不提取為多帶帶css文件的scss樣式 應該使用的 LOADER。即使用style-loader將 scss 處理成 css 嵌入網頁代碼。
注意 2中的allChunks必須指明為false。否則會包括異步加載的 CSS!
3. SCSS引用和懶加載在項目入口文件app.js中,針對 scss 懶加載,需要引入以下配置代碼:
import "style-loader/lib/addStyles"; import "css-loader/lib/css-base";
剩下我們先設置背景色為紅色,在用戶點擊鼠標后,懶加載common.scss,使背景色變為綠色。剩余代碼如下:
import "./scss/base.scss"; var loaded = false; window.addEventListener("click", function() { if (!loaded) { import(/* webpackChunkName: "style"*/ "./scss/common.scss").then(_ => { // chunk-name : style console.log("Change bg-color of html"); loaded = true; }); } });4. 打包和引入
根據我們在app.js中的webpackChunkName的配置,可以猜測,打包結果中有:style.chunk.js 文件。
命令行執行webpack打包后,/dist/目錄中的打包結果如下:
最后,我們需要在 html 代碼中引入打包結果中的、非懶加載的樣式(/dist/app.min.css)和 js 文件(/dist/app.bundle.js)。
Document
終
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/97282.html
摘要:全網最貼心系列教程和配套代碼歡迎關注個人技術博客。所以我花費了個多月整理了這份教程,一共分成節,每節都有講解,并且準備了配套代碼。奈何深感水平不夠,只有一腔熱情,所以直接開放了教程和源碼。 webpack-demos:全網最貼心 webpack 系列教程和配套代碼 歡迎關注個人技術博客:godbmw.com。每周 1 篇原創技術分享!開源教程(webpack、設計模式)、面試刷題(偏前...
摘要:課程地址全部課程地址立即進入課程源碼目錄截至按照知識點,目錄分成了個文件夾之后還會持續更新。個人網站原文鏈接系列教程前言 本文檔已經過時,最近內容請看:https://godbmw.com/passage/76。一共16節課程和代碼。謝謝支持。 1. 什么是webpack? 前端目前最主流的javascript打包工具,在它的幫助下,開發者可以輕松地實現加密代碼、多平臺兼容。而最重要的...
摘要:本節課講解打包單頁應用過程中的代碼分割和代碼懶加載。不同于多頁面應用的提取公共代碼,單頁面的代碼分割和懶加載不是通過配置來實現的,而是通過的寫法和內置函數實現的。個人網站原文鏈接系列教程四單頁面解決方案代碼分割和懶加載 本節課講解webpack4打包單頁應用過程中的代碼分割和代碼懶加載。不同于多頁面應用的提取公共代碼,單頁面的代碼分割和懶加載不是通過webpack配置來實現的,而是通過...
摘要:只需要在處理的配置上增加編譯的即可。了解更多處理的內容本節課源碼所有課程源碼教程所示圖片使用的是倉庫圖片,網速過慢的朋友請移步原文地址系列教程六處理。根據規則放在最后的首先被執行。 這節課講解webpack4中處理scss。只需要在處理css的配置上增加編譯scss的 LOADER 即可。了解更多處理css的內容 >>> >>> 本節課源碼 >>> 所有課程源碼 教程所示圖片使用的是...
摘要:然而,瀏覽器對這些高級語法的支持性并不是非常好。是一個編譯器,能夠讓我們放心的使用新一代語法。在中使用安裝修改,加入新的遇到文件就先用處理,表示排除文件夾中的文件。 1. 什么是Babel 如今 ES6 語法在開發中已經非常普及,甚至也有許多開發人員用上了 ES7 或 ES8 語法。然而,瀏覽器對這些高級語法的支持性并不是非常好。因此為了讓我們的新語法能在瀏覽器中都能順利運行,Babe...
閱讀 2526·2021-09-26 10:18
閱讀 3399·2021-09-22 10:02
閱讀 3209·2019-08-30 15:44
閱讀 3336·2019-08-30 15:44
閱讀 1841·2019-08-29 15:25
閱讀 2587·2019-08-26 14:04
閱讀 2052·2019-08-26 12:15
閱讀 2449·2019-08-26 11:43