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

解決vue熱替換失效的根本原因

 更新時(shí)間:2018年09月19日 09:48:14   作者:ifredom  
今天小編就為大家分享一篇解決vue熱替換失效的根本原因,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

新手剛開(kāi)始使用vue時(shí),常會(huì)遇見(jiàn)一個(gè)坑,那就是熱替換失效。

什么?你跟我說(shuō)使用官方的vue-cli去構(gòu)建,我就是使用vue-cli后突然失效。

什么?你跟我說(shuō)重新npm run dev一下,好嘛,已經(jīng)run了N次了依然沒(méi)回到大路上。

經(jīng)過(guò)在網(wǎng)上一番查找,發(fā)現(xiàn)基本沒(méi)有這個(gè)問(wèn)題的詳解,可能是這個(gè)問(wèn)題太低級(jí)了?

講解一下熱替換的原理:熱替換是在執(zhí)行npm run dev后,會(huì)啟動(dòng)一個(gè)本地服務(wù)器(webpack-dev-server),這個(gè)服務(wù)器會(huì)觀察源代碼編譯出來(lái)的文件。一旦修改了源代碼,就會(huì)立刻編譯源代碼,然后觀察新編譯后的文件,接下來(lái)替換。

為什么會(huì)有編譯這個(gè)以過(guò)程,就是因?yàn)槭褂?vue開(kāi)發(fā)時(shí),瀏覽器不認(rèn)識(shí)這種類型的文件,需要編譯成js文件。

所以整個(gè)過(guò)程可以這樣描述:

源代碼 ---> 編譯為目標(biāo)代碼(瀏覽器可以識(shí)別運(yùn)行的代碼) ---> 本地服務(wù)器觀察目標(biāo)代碼 ----> 本地服務(wù)器接收到目標(biāo)代碼改變[事件] ----> 刷新瀏覽器

常見(jiàn)熱替換失效導(dǎo)致的原因:

1.觀察文件位置錯(cuò)誤

{

 env: require('./dev.env'),
 port: 8080,
 autoOpenBrowser: true,
 assetsSubDirectory: 'static',//必須
 assetsPublicPath: '/',

失效是為什么?是因?yàn)樾薷牧嗽创a后,依然會(huì)立刻編譯,但是通常被觀察的新編譯的文件位置錯(cuò)了。也就是說(shuō)瀏覽器顯示的東西與服務(wù)器觀察的東西是一個(gè)位置,而編譯出來(lái)文件是另外的位置。

解決辦法是:config/index.js中 dev的這個(gè)參數(shù)必須為static

2.項(xiàng)目目錄包含特殊字符

像這樣的路徑 D:\(myworkspace)\vue-answer-project

這種目錄中有一個(gè)括號(hào)!??!就有可能在瀏覽器中打開(kāi)后,發(fā)現(xiàn)console報(bào)錯(cuò)

http://localhost:8080/__webpack_hmr net::ERR_INCOMPLETE_CHUNKED_ENCODING

這是什么意思呢?就是熱替換模塊報(bào)錯(cuò),中斷了觀察頁(yè)面與熱替換模塊的鏈接,無(wú)法收到事件。

解決辦法就是:去掉這樣的路徑

3.npm run build后,打開(kāi)瀏覽器一片空白

這個(gè)位置是根據(jù)文件webpack.config.js中的publicPath進(jìn)行指定的。也就是服務(wù)器觀察位置是 publicPath: "XX/build.js"這里面的 /XX/build.js這個(gè)文件,這個(gè)文件需要你在文件 index.html中 正確引入。

// webpack編譯輸出的發(fā)布路徑
// => 將 build 的路徑前綴修改為 ' ./ '(原本為 ' / '),是因?yàn)榇虬?npm run build)之后,
// 外部引入 js 和 css 文件時(shí),如果路徑以 ' / ' 開(kāi)頭,在本地是無(wú)法找到對(duì)應(yīng)文件的(服務(wù)器上沒(méi)問(wèn)題)
module.exports = {
 build: {
 env: require('./prod.env'),
 index: path.resolve(__dirname, '../dist/index.html'),
 assetsRoot: path.resolve(__dirname, '../dist'),
 assetsSubDirectory: 'static',
 assetsPublicPath: './',
 productionSourceMap: true,
 // Gzip off by default as many popular static hosts such as
 // Surge or Netlify already gzip all static assets for you.
 // Before setting to `true`, make sure to:
 // npm install --save-dev compression-webpack-plugin
 productionGzip: false,
 productionGzipExtensions: ['js', 'css'],
 // Run the build command with an extra argument to
 // View the bundle analyzer report after build finishes:
 // `npm run build --report`
 // Set to `true` or `false` to always turn it on or off
 bundleAnalyzerReport: process.env.npm_config_report
 },
 dev: {
 env: require('./dev.env'),
 port: 8081,
 autoOpenBrowser: true,
 assetsSubDirectory: 'static',
 assetsPublicPath: '/',
 proxyTable: {},
 // CSS Sourcemaps off by default because relative paths are "buggy"
 // with this option, according to the CSS-Loader README
 // (https://github.com/webpack/css-loader#sourcemaps)
 // In our experience, they generally work as expected,
 // just be aware of this issue when enabling this option.
 cssSourceMap: true
 }

解決辦法是:在上圖中的build.assetsPublicPath的值 改為 "./"

以上這篇解決vue熱替換失效的根本原因就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue組件tabbar使用方法詳解

    vue組件tabbar使用方法詳解

    這篇文章主要為大家詳細(xì)介紹了vue組件tabbar使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • vue 本地服務(wù)不能被外部IP訪問(wèn)的完美解決方法

    vue 本地服務(wù)不能被外部IP訪問(wèn)的完美解決方法

    這篇文章主要介紹了vue 本地服務(wù)不能被外部IP訪問(wèn)的解決方法,本文通過(guò)代碼講解的非常詳細(xì),需要的朋友可以參考下
    2018-10-10
  • Vue2.0學(xué)習(xí)之詳解Vue 組件及父子組件通信

    Vue2.0學(xué)習(xí)之詳解Vue 組件及父子組件通信

    本篇文章主要介紹了Vue2.0學(xué)習(xí)之詳解Vue 組件及父子組件通信,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • Vue3+Element?Plus使用svg加載iconfont的處理方法

    Vue3+Element?Plus使用svg加載iconfont的處理方法

    這篇文章主要介紹了Vue3+Element?Plus使用svg加載iconfont的解決方案,本文詳細(xì)介紹了如何在Element?Plus中使用iconfont,簡(jiǎn)單的說(shuō)就是要將其封裝成SVG,并且支持動(dòng)態(tài)修改顏色,需要的朋友可以參考下
    2022-08-08
  • Vue2.0 http請(qǐng)求以及l(fā)oading展示實(shí)例

    Vue2.0 http請(qǐng)求以及l(fā)oading展示實(shí)例

    下面小編就為大家分享一篇Vue2.0 http請(qǐng)求以及l(fā)oading展示實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • vue?文件切片上傳的項(xiàng)目實(shí)現(xiàn)

    vue?文件切片上傳的項(xiàng)目實(shí)現(xiàn)

    本文主要介紹了vue?文件切片上傳的項(xiàng)目實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • 詳解Vue.js使用Swiper.js在iOS<11時(shí)出現(xiàn)錯(cuò)誤

    詳解Vue.js使用Swiper.js在iOS<11時(shí)出現(xiàn)錯(cuò)誤

    這篇文章主要介紹了詳解Vue.js使用Swiper.js在iOS<11時(shí)出現(xiàn)錯(cuò)誤,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • VueJS實(shí)現(xiàn)用戶管理系統(tǒng)

    VueJS實(shí)現(xiàn)用戶管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了VueJS實(shí)現(xiàn)用戶管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • vue框架編輯接口頁(yè)面下拉級(jí)聯(lián)選擇并綁定接口所屬模塊

    vue框架編輯接口頁(yè)面下拉級(jí)聯(lián)選擇并綁定接口所屬模塊

    這篇文章主要為大家介紹了vue框架編輯接口頁(yè)面實(shí)現(xiàn)下拉級(jí)聯(lián)選擇以及綁定接口所屬模塊,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • vue2安裝tailwindcss的詳細(xì)步驟

    vue2安裝tailwindcss的詳細(xì)步驟

    這篇文章主要介紹了vue2安裝tailwindcss,本文分步驟結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-08-08

最新評(píng)論