這篇文章主要介紹如何解決Vue中SSR組件加載問題,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
主要從事網頁設計、PC網站建設(電腦版網站建設)、wap網站建設(手機版網站建設)、響應式網站設計、程序開發(fā)、微網站、微信小程序等,憑借多年來在互聯(lián)網的打拼,我們在互聯(lián)網網站建設行業(yè)積累了豐富的成都網站建設、網站制作、網絡營銷經驗,集策劃、開發(fā)、設計、營銷、管理等多方位專業(yè)化運作于一體,具備承接不同規(guī)模與類型的建設項目的能力。Node 端渲染提示 window/document 沒有定義
業(yè)務場景
首先來看一個簡單的 Vue 組件 test.vue
clientHeight: {{ clientHeight }} px
上面 test.vue 組件通過 Vue computed 屬性 clientHeight 直接獲取 document 的文檔高度,這段代碼在前端渲染是不會報錯的,也能拿到正確的值。但如果把這個組件放到 SSR(Server Side Render) 模式下, 就會報如下錯誤:
ReferenceError: document is not defined
解決方案
通過 typeof 判斷是否是存在 document 對象, 如果存在則執(zhí)行后面代碼。 這種方式雖然能解決問題, 但在 Webpack 構建壓縮時, 不會執(zhí)行的代碼不會被剔除,也會打包到 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 的常量。 因為這個是構建期間執(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 來決定是否渲染該組件
Vue 只在前端掛載組件解決問題
loading 組件因為沒有注冊, 在 SSR 模式,
以上是“如何解決Vue中SSR組件加載問題”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道!