日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > CSS >内容正文

CSS

webpack 3 零基础入门教程 #12 - 如何使用模块热替换 HMR 来处理 CSS

發布時間:2025/3/8 CSS 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 webpack 3 零基础入门教程 #12 - 如何使用模块热替换 HMR 来处理 CSS 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

模塊熱替換 是什么意思?

以前我們使用的 webpack --watch 或 webpack-dev-server 的功能是監聽文件改變,就自動刷新瀏覽器,而這個 模塊熱替換 不用刷新瀏覽器,它是只讓修改到的模塊,才會在瀏覽器上發生相應的變化,就是生效,而不是重新刷新瀏覽器。

為什么要這么做呢?有時候模塊越多,改得頻繁,刷新起來還是很慢的,效率低呀。

所以有了 模塊熱替換 的功能,我們來試一下,讓我們一改 CSS 然后瀏覽器不用刷新就會讓頁面生效改變。

1. 啟用 HMR

webpack.config.js

devServer: {port: 9000,open: true,} 復制代碼

改成下面這樣:

devServer: {port: 9000,open: true,hot: true} 復制代碼

webpack.config.js

... const webpack = require('webpack');...module.exports = {entry: {"app.bundle": './src/app.js',"contact": './src/contact.js'},output: {path: path.resolve(__dirname, 'dist'),filename: '[name].[chunkhash].js'},devServer: {port: 9000,open: true,hot: true},plugins: [new CleanWebpackPlugin(pathsToClean),...// 這兩行是新增的new webpack.NamedModulesPlugin(),new webpack.HotModuleReplacementPlugin()],... };復制代碼

可惜,報錯了個錯:

文件名還不能用 chunkhash 了,它說要用 hash 來代替 chunkhash。

我們來改一下:

filename: '[name].[chunkhash].js' 復制代碼

變成

filename: '[name].[hash].js' 復制代碼

2. 處理 extract-text-webpack-plugin

現在你試一下改變 src/app.scss 的內容,你會發現頁面不動了,你無論怎么改,頁面都不會改變,也不會刷新。

之前我們是用 extract-text-webpack-plugin 這個插件來處理 CSS 的,在用 HMR 的時候要先把它關閉一下。

用一個參數 disable: true 就可以關閉掉。

webpack.config.js

new ExtractTextPlugin("style.css") 復制代碼

變成

new ExtractTextPlugin({filename: 'style.css',disable: true }), 復制代碼

然后把處理 scss 文件的 loader 部分變成類似下面這樣:

...test: /\.scss$/,use: ExtractTextPlugin.extract({fallback: 'style-loader',//resolve-url-loader may be chained before sass-loader if necessaryuse: ['css-loader', 'sass-loader']}) ... 復制代碼

變成

...test: /\.scss$/,use: ['style-loader', 'css-loader', 'sass-loader'] ... 復制代碼

再試試,能夠生效。

為什么要關閉呢這個插件呢?

其實想想也能知道,在開發環境下,用不用 extract-text-webpack-plugin 這個插件,意義不大,你把 css 變不變成一個文件,關系不大,開發環境只要能調效,效果能夠看到就可以,但是生產環境需要這個插件,我們總不能開發環境不使用這個插件,也導致生產環境也不使用吧?

那如何解決這個問題呢?也就是說讓生產環境使用這個插件,而開發環境不使用,我們下節來討論這個問題。

先這么多吧。

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的webpack 3 零基础入门教程 #12 - 如何使用模块热替换 HMR 来处理 CSS的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。