亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue SSR 組件加載問(wèn)題

 更新時(shí)間:2018年05月02日 11:44:12   投稿:mrr  
這篇文章主要介紹了Vue SSR 組件加載問(wèn)題,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下

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

業(yè)務(wù)場(chǎng)景

首先來(lái)看一個(gè)簡(jiǎn)單的 Vue 組件 test.vue

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

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

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

解決方案

通過(guò) typeof 判斷是否是存在 document 對(duì)象, 如果存在則執(zhí)行后面代碼。 這種方式雖然能解決問(wèn)題, 但在 Webpack 構(gòu)建壓縮時(shí), 不會(huì)執(zhí)行的代碼不會(huì)被剔除,也會(huì)打包到 js 文件中去, 因?yàn)檫@個(gè)是在運(yùn)行期才知道結(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   進(jìn)行 判斷。 這樣在構(gòu)建壓縮期間, 如果是 Node 模式構(gòu)建, EASY_ENV_IS_BROWSER 會(huì)被替換為 false,如果是 Browser 模式構(gòu)建, EASY_ENV_IS_BROWSER 會(huì)被替換為 true,最后構(gòu)建后代碼也就是變成了 true 或者 false 的常量。 因?yàn)檫@個(gè)是構(gòu)建期間執(zhí)行的,壓縮插件剔除永遠(yuǎn)不會(huì)被執(zhí)行的代碼, 也就是

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

NPM Vue 組件 SSR 支持

針對(duì)上面這種自己寫的代碼,我們可以通過(guò)這種方式解決,因?yàn)榭梢灾苯有薷摹5绻覀円氲囊粋€(gè) npm Vue 插件想進(jìn)行SSR渲染, 但這個(gè)插件里面使用了 window/docment 等瀏覽器對(duì)象, 并沒有對(duì) SSR 模式進(jìn)行兼容,這個(gè)時(shí)候該如何解決呢?

一般我們通過(guò) 通過(guò) v-if 來(lái)決定是否渲染該組件 和 Vue 只在前端掛載組件解決問(wèn)題 可以解決。

通過(guò) v-if 來(lái)決定是否渲染該組件

<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 只在前端掛載組件解決問(wèn)題

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

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

loading 組件因?yàn)闆]有注冊(cè), 在 SSR 模式, <Loading></Loading> 會(huì)被原樣輸出到 HTML 中,不會(huì)報(bào)錯(cuò)且不能被瀏覽器識(shí)別, 在顯示時(shí)不會(huì)有內(nèi)容。當(dāng) SSR 直出 HTML 后,瀏覽器模式中執(zhí)行 beforeMount 掛載組件, 從而達(dá)到解決服務(wù)端渲染報(bào)錯(cuò)的問(wèn)題

https:// github.com/hubcarl/egg- vue-webpack-boilerplate/blob/master/app/web/page/dynamic/dynamic.vue

總結(jié)

以上所述是小編給大家介紹的Vue SSR 組件加載問(wèn)題,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vue實(shí)現(xiàn)循環(huán)切換動(dòng)畫

    vue實(shí)現(xiàn)循環(huán)切換動(dòng)畫

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)循環(huán)切換動(dòng)畫,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • vue2.0的計(jì)算屬性computed和watch的區(qū)別及各自?使用場(chǎng)景解讀

    vue2.0的計(jì)算屬性computed和watch的區(qū)別及各自?使用場(chǎng)景解讀

    這篇文章主要介紹了vue2.0的計(jì)算屬性computed和watch的區(qū)別及各自?使用場(chǎng)景,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Vue from-validate 表單驗(yàn)證的示例代碼

    Vue from-validate 表單驗(yàn)證的示例代碼

    本篇文章主要介紹了Vue from-validate 表單驗(yàn)證的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • VueJs 將接口用webpack代理到本地的方法

    VueJs 將接口用webpack代理到本地的方法

    本篇文章主要介紹了VueJs 將接口用webpack代理到本地的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-11-11
  • 詳解vue 組件的實(shí)現(xiàn)原理

    詳解vue 組件的實(shí)現(xiàn)原理

    這篇文章主要介紹了詳解vue 組件的實(shí)現(xiàn)原理,幫助大家更好的理解和學(xué)習(xí)vue框架,感興趣的朋友可以了解下
    2020-11-11
  • vue 使用iView組件中的Table實(shí)現(xiàn)定時(shí)自動(dòng)滾動(dòng)效果

    vue 使用iView組件中的Table實(shí)現(xiàn)定時(shí)自動(dòng)滾動(dòng)效果

    要在css中設(shè)置table的高度,使數(shù)據(jù)過(guò)多時(shí)出現(xiàn)滾動(dòng)條,將縱向設(shè)置為overflow-y: auto;橫向設(shè)置隱藏 overflow-x: hidden,接下來(lái)通過(guò)本文介紹vue使用iView組件中的Table實(shí)現(xiàn)定時(shí)自動(dòng)滾動(dòng)效果,需要的朋友可以參考下
    2024-05-05
  • 淺談webpack SplitChunksPlugin實(shí)用指南

    淺談webpack SplitChunksPlugin實(shí)用指南

    這篇文章主要介紹了淺談webpack SplitChunksPlugin實(shí)用指南,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • 記一次Vue中$route序列號(hào)報(bào)錯(cuò)

    記一次Vue中$route序列號(hào)報(bào)錯(cuò)

    本文主要介紹了記一次Vue中$route序列號(hào)報(bào)錯(cuò),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • vue.js管理后臺(tái)table組件封裝的方法

    vue.js管理后臺(tái)table組件封裝的方法

    table作為數(shù)據(jù)展示組件,在日常開發(fā)中經(jīng)常被用到,這篇文章主要給大家介紹了關(guān)于vue.js管理后臺(tái)table組件封裝的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-08-08
  • vue中data里面的數(shù)據(jù)相互使用方式

    vue中data里面的數(shù)據(jù)相互使用方式

    這篇文章主要介紹了vue中data里面的數(shù)據(jù)相互使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06

最新評(píng)論