亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Vue SSR 組件加載問題

2019-11-19 13:55:54
字體:
來源:轉載
供稿:網友

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

業務場景

首先來看一個簡單的 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 組件通過 Vue computed 屬性 clientHeight 直接獲取 document 的文檔高度,這段代碼在前端渲染是不會報錯的,也能拿到正確的值。但如果把這個組件放到 SSR(Server Side Render) 模式下, 就會報如下錯誤:
ReferenceError: document is not defined

解決方案

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

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

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

dead_codeclientHeight() {  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() {   // 只會在瀏覽器執行    this.$options.components.Loading = () =>import('vue-loading');  },  mounted(){  } }</script>

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

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

總結

以上所述是小編給大家介紹的Vue SSR 組件加載問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲天堂一区二区三区| 欧美日韩一区二区在线播放| 色系列之999| 国产+人+亚洲| xxxx性欧美| 欧美极品少妇xxxxⅹ裸体艺术| 精品国产欧美一区二区三区成人| 成人网页在线免费观看| 国产在线日韩在线| 国外色69视频在线观看| 欧洲一区二区视频| 国产精品专区一| 欧美性xxxx极品高清hd直播| 欧美成人激情图片网| 中文字幕日韩精品有码视频| 国产精品白嫩初高中害羞小美女| 中文字幕亚洲一区| 久久精品国产清自在天天线| 欧美第一淫aaasss性| 欧美国产日韩视频| 国产精品久久一区主播| 久久99国产精品自在自在app| 国产深夜精品福利| 欧美电影免费观看电视剧大全| 日韩欧美第一页| 成人免费视频网| 成人动漫网站在线观看| 亚洲精品资源美女情侣酒店| 久久久久久久久中文字幕| 国产精品一区二区av影院萌芽| 日韩电视剧免费观看网站| 日韩中文字幕第一页| 欧美成人中文字幕| 91精品国产乱码久久久久久蜜臀| 在线观看精品国产视频| 欧美中文字幕精品| 综合网中文字幕| 久久久伊人欧美| 成人黄色av网| 91精品国产综合久久久久久久久| 一区二区三区四区精品| 欧美成人免费视频| 91干在线观看| 欧美大全免费观看电视剧大泉洋| 日韩动漫免费观看电视剧高清| 国产日韩欧美日韩大片| 中文日韩在线观看| 欧美激情a∨在线视频播放| 国产精品久久999| 国产日韩av高清| 国产精品一区二区久久久| 91免费国产网站| 久久久久久久激情视频| 国产精品精品国产| 日韩av在线电影网| 最新亚洲国产精品| 国产精品久久久久一区二区| 欧美激情国内偷拍| 日韩男女性生活视频| 亚洲性生活视频在线观看| 日韩成人av网址| 91精品久久久久久久久久久| 欧美激情图片区| 国产精品自在线| 精品久久久久久久久久ntr影视| 欧美日韩在线观看视频小说| 色综合久久88| xvideos国产精品| 78色国产精品| 91久久国产婷婷一区二区| 91精品国产乱码久久久久久久久| 欧美国产日韩xxxxx| 日本韩国欧美精品大片卡二| 亚洲区免费影片| 国产成人精品视频在线观看| 日韩亚洲成人av在线| 久久久久久久成人| 中文字幕久热精品视频在线| 亚洲成人aaa| 国产亚洲精品久久久| 国产精品久久久久久久久久三级| 欧美精品少妇videofree| 最近2019年日本中文免费字幕| 日韩精品久久久久久福利| 欧美黄色成人网| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲精品一区中文字幕乱码| 国产精品久久久久久影视| 国产成人精品国内自产拍免费看| 日本一区二区三区四区视频| 777777777亚洲妇女| 欧美成人全部免费| 欧美最猛性xxxx| 国产精品热视频| 国产日韩中文字幕在线| 91精品国产综合久久久久久久久| 中文字幕在线看视频国产欧美| 欧美在线视频免费| 国产亚洲精品久久久久久| 国产精品揄拍一区二区| 亚洲欧美制服综合另类| 久久人人97超碰精品888| 国内免费精品永久在线视频| 欧美性色19p| 久久久久久午夜| 日韩精品中文在线观看| 成人做爰www免费看视频网站| 欧洲永久精品大片ww免费漫画| 国产精品视频xxxx| 国产精品三级美女白浆呻吟| 91社影院在线观看| 97av在线播放| 国产精品视频免费在线观看| 综合136福利视频在线| 国产亚洲精品91在线| 亚洲跨种族黑人xxx| 亚洲成人精品av| 国产日韩欧美日韩| 欧美在线免费观看| 亚洲品质视频自拍网| 久久精品国产亚洲| 亚洲欧美一区二区激情| 亚洲第一区第一页| 全亚洲最色的网站在线观看| 亚洲精品日韩丝袜精品| 国产精品久久久久久av下载红粉| 亚洲精品综合久久中文字幕| 亚洲片国产一区一级在线观看| 亚洲最大成人免费视频| 伊人久久免费视频| 精品国产福利视频| 欧美日韩国产丝袜另类| 亚洲肉体裸体xxxx137| 亚洲男人7777| 亚洲网站在线播放| 成人黄色短视频在线观看| 91精品国产综合久久香蕉| 国产精品热视频| 一区二区三区视频免费| 性欧美长视频免费观看不卡| 在线观看国产精品91| 最新中文字幕亚洲| 亚洲www在线| 国产欧美日韩中文字幕在线| 亚洲精品黄网在线观看| 久久久中文字幕| 日韩视频精品在线| 午夜精品福利在线观看| 国产精品国内视频| 国语自产在线不卡| 欧洲成人午夜免费大片| 国模精品一区二区三区色天香| 亚洲福利在线看| 欧美大片免费观看在线观看网站推荐| 欧美乱大交xxxxx| 美女福利视频一区| 日韩中文在线中文网在线观看| 日韩精品视频观看| 国模精品一区二区三区色天香| 欧美在线中文字幕| 国产精品视频最多的网站| 国产日本欧美一区二区三区| 最近日韩中文字幕中文| 国产精品va在线|