成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

如何解決Vue中SSR組件加載問題-創(chuàng)新互聯(lián)

這篇文章主要介紹如何解決Vue中SSR組件加載問題,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

主要從事網(wǎng)頁設計、PC網(wǎng)站建設(電腦版網(wǎng)站建設)、wap網(wǎng)站建設(手機版網(wǎng)站建設)、響應式網(wǎng)站設計、程序開發(fā)、微網(wǎng)站、微信小程序等,憑借多年來在互聯(lián)網(wǎng)的打拼,我們在互聯(lián)網(wǎng)網(wǎng)站建設行業(yè)積累了豐富的成都網(wǎng)站建設、網(wǎng)站制作、網(wǎng)絡營銷經(jīng)驗,集策劃、開發(fā)、設計、營銷、管理等多方位專業(yè)化運作于一體,具備承接不同規(guī)模與類型的建設項目的能力。

Node 端渲染提示 window/document 沒有定義

如何解決Vue中SSR組件加載問題

業(yè)務場景

首先來看一個簡單的 Vue 組件 test.vue

<template>
 <div>
  <h3>clientHeight: {{ clientHeight }} px </h3>
 </div>
</template>

<script type="text/babel">
 export default {
  data(){
   return {
   }
  },
  computed :{
   clientHeight() {
    return document.body.clientHeight;
   }
  },
  mounted(){
  }
 }
</script>

上面 test.vue 組件通過 Vue computed 屬性 clientHeight 直接獲取 document 的文檔高度,這段代碼在前端渲染是不會報錯的,也能拿到正確的值。但如果把這個組件放到 SSR(Server Side Render) 模式下, 就會報如下錯誤:
ReferenceError: document is not defined

解決方案

通過 typeof 判斷是否是存在 document 對象, 如果存在則執(zhí)行后面代碼。 這種方式雖然能解決問題, 但在 Webpack 構(gòu)建壓縮時, 不會執(zhí)行的代碼不會被剔除,也會打包到 js 文件中去, 因為這個是在運行期才知道結(jié)果的, 所以在 Webpack 構(gòu)建方案中,不建議使用 typeof 方式判斷。而是使用 Webpack 提供的 webpack.DefinePlugin 插件定義常量解決。

clientHeight() {
  return typeof document === 'object' ? document.body.clientHeight : '';
}

使用 Webpack 提供的 webpack.DefinePlugin 插件定義常量解決。 這里直接使用 easywebpack     https:// github.com/hubcarl/easy    webpack   內(nèi)置的全局 Webpack 常量 EASY_ENV_IS_BROWSER  http:// hubcarl.github.io/easyw ebpack/webpack/env   進行 判斷。 這樣在構(gòu)建壓縮期間, 如果是 Node 模式構(gòu)建, EASY_ENV_IS_BROWSER 會被替換為 false,如果是 Browser 模式構(gòu)建, EASY_ENV_IS_BROWSER 會被替換為 true,最后構(gòu)建后代碼也就是變成了 true 或者 false 的常量。 因為這個是構(gòu)建期間執(zhí)行的,壓縮插件剔除永遠不會被執(zhí)行的代碼, 也就是

dead_code
clientHeight() {
  return EASY_ENV_IS_BROWSER ? document.body.clientHeight : '';
}

NPM Vue 組件 SSR 支持

針對上面這種自己寫的代碼,我們可以通過這種方式解決,因為可以直接修改。但如果我們引入的一個 npm Vue 插件想進行SSR渲染, 但這個插件里面使用了 window/docment 等瀏覽器對象, 并沒有對 SSR 模式進行兼容,這個時候該如何解決呢?

一般我們通過 通過 v-if 來決定是否渲染該組件 和 Vue 只在前端掛載組件解決問題 可以解決。

通過 v-if 來決定是否渲染該組件

<template>
 <div v-if="isBrowser">
  <Loading></Loading>
 </div>
</template>
<script type="text/babel">
 export default {
  componets:{
   Loading: () =>import('vue-loading');
  }
  data(){
   return {
    isBrowser: EASY_ENV_IS_BROWSER
   }
  },
  mounted(){
  }
 }
</script>

Vue 只在前端掛載組件解決問題

<template>
 <div>
  <Loading></Loading>
 </div>
</template>

<script type="text/babel">
 export default {
  data(){
   return {
   }
  },
  beforeMount() {
   // 只會在瀏覽器執(zhí)行 
   this.$options.components.Loading = () =>import('vue-loading');
  },
  mounted(){
  }
 }
</script>

loading 組件因為沒有注冊, 在 SSR 模式, <Loading></Loading> 會被原樣輸出到 HTML 中,不會報錯且不能被瀏覽器識別, 在顯示時不會有內(nèi)容。當 SSR 直出 HTML 后,瀏覽器模式中執(zhí)行 beforeMount 掛載組件, 從而達到解決服務端渲染報錯的問題

以上是“如何解決Vue中SSR組件加載問題”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

本文名稱:如何解決Vue中SSR組件加載問題-創(chuàng)新互聯(lián)
鏈接分享:http://jinyejixie.com/article42/dposhc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供Google、外貿(mào)建站自適應網(wǎng)站、網(wǎng)站策劃、搜索引擎優(yōu)化、標簽優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設
黎平县| 双鸭山市| 海兴县| 慈溪市| 台东县| 长治县| 时尚| 巍山| 永登县| 潮安县| 诸城市| 冀州市| 天水市| 东兰县| 滁州市| 马关县| 双鸭山市| 昂仁县| 南城县| 都江堰市| 阜新市| 汝阳县| 呈贡县| 鄂尔多斯市| 石阡县| 孟村| 吉木乃县| 木兰县| 西乌珠穆沁旗| 美姑县| 六盘水市| 苍梧县| 偃师市| 天长市| 买车| 尖扎县| 南郑县| 常宁市| 常熟市| 桃园县| 郴州市|