<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        Vue SSR 組件加載問題

        來源:懂視網 責編:小采 時間:2020-11-27 22:15:42
        文檔

        Vue SSR 組件加載問題

        Vue SSR 組件加載問題:Node 端渲染提示 window/document 沒有定義 業務場景 首先來看一個簡單的 Vue 組件 test.vue <template> <div> <h2>clientHeight: {{ clientHeight }} px </h2> </div> <
        推薦度:
        導讀Vue SSR 組件加載問題:Node 端渲染提示 window/document 沒有定義 業務場景 首先來看一個簡單的 Vue 組件 test.vue <template> <div> <h2>clientHeight: {{ clientHeight }} px </h2> </div> <

        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_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() {
         // 只會在瀏覽器執行 
         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 組件加載問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        Vue SSR 組件加載問題

        Vue SSR 組件加載問題:Node 端渲染提示 window/document 沒有定義 業務場景 首先來看一個簡單的 Vue 組件 test.vue <template> <div> <h2>clientHeight: {{ clientHeight }} px </h2> </div> <
        推薦度:
        標簽: 加載 VUE ssr
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲乱码日产精品BD在线观看| 国产一卡2卡3卡4卡2021免费观看| 日韩精品无码免费专区午夜 | 亚洲国产美国国产综合一区二区| 亚洲成a人片在线观看精品| 最近中文字幕高清免费中文字幕mv | 暖暖日本免费在线视频| 亚洲午夜福利717| 亚洲最大无码中文字幕| 成人片黄网站A毛片免费| 一本色道久久88—综合亚洲精品| 成人影片一区免费观看| 亚洲人成在线观看| 国产曰批免费视频播放免费s | 亚洲妇女水蜜桃av网网站| 青青草a免费线观a| 欧洲亚洲国产清在高| 四虎国产精品永久免费网址 | 亚洲AV无码一区东京热| 99久久久国产精品免费牛牛| 伊人亚洲综合青草青草久热| 亚洲午夜国产精品| 精品国产精品久久一区免费式| 亚洲第一区视频在线观看| 一区二区三区免费高清视频| 24小时免费直播在线观看| 亚洲午夜久久影院| 日韩一区二区a片免费观看| jzzijzzij在线观看亚洲熟妇| 国产又大又粗又长免费视频 | 精品久久久久久亚洲| 蜜桃AV无码免费看永久| 亚洲AV成人无码网站| 亚洲熟妇av一区二区三区| aa级一级天堂片免费观看| 亚洲福利视频一区二区三区| 国内精品久久久久影院免费| 中文字幕精品无码亚洲字| 亚洲av日韩av永久在线观看| 成人人观看的免费毛片| 亚洲sss综合天堂久久久|