• 當前位置:首頁 > IT技術 > Web編程 > 正文

    Vue.js項目加載速度性能優化
    2022-04-29 14:09:19


    隨著項目引入的依賴增多,每次打開項目,無論是開發環境還是生產環境,都逐步變慢。開始沒有感覺不明顯,隨著項目迭代次數增多,網站打開速度有了明顯的卡頓感。

    外部第三方依賴,一般都是固定的版本,不會隨著項目進行而改變,可以利用cdn加載,和瀏覽器本身的緩存機制實現網站打開速度的提升。

    本次優化按照如下步驟進行:

    1、外部引入第三方庫

    將用到的第三方庫,都做外部引入

    vue.config.js

    // from vue import Vue
    externals: {
    vue: 'Vue',
    vuex: 'Vuex',
    'vue-router': 'VueRouter',
    axios: 'axios',
    moment: 'moment',
    lodash: '_',
    echarts: 'echarts'
    },


    可參考: ??webpack 外部擴展(Externals)??


    2、配置環境變量

    2.1、開發環境配置

    .env.development

    # 環境標識
    ENV = 'development'

    # 開發環境靜態資源cdn地址
    VUE_APP_CDN_BASE_URL = "https://mouday.github.io/more-cdn"

    2.2、生產環境配置

    .env.production

    # 環境標識
    ENV = 'production'

    # 生產環境靜態資源cdn地址
    VUE_APP_CDN_BASE_URL = "https://mouday.github.io/more-cdn"

    可用的公共CDN

    • https://www.bootcdn.cn/
    • https://cdnjs.com/

    需要注意的是,公共CDN可能不穩定,我們剛開始就使用了bootcdn作為生產環境的CDN,沒想到過了幾天網站掛了。

    強烈推薦使用自建CDN,保證穩定性。

    此處推薦一個CDN模板,可以把需要的第三方依賴下載到項目,自行部署一個靜態資源CDN

    ??https://github.com/mouday/more-cdn??


    可參考:??Vue CLI 模式和環境變量??


    3、配置外部依賴包CDN加載

    Vue需要區分開發環境和線上環境,開發環境加載未壓縮的代碼,便于調試

    public/index.html

    <!-- 開發環境加載未打包依賴 -->
    <% if (ENV = 'development') { %>
    <script src="<%= VUE_APP_CDN_BASE_URL %>/ajax/libs/vue/2.6.10/vue.js"></script>
    <% } else { %>
    <script src="<%= VUE_APP_CDN_BASE_URL %>/ajax/libs/vue/2.6.10/vue.min.js"></script>
    <% }%>

    <script src="<%= VUE_APP_CDN_BASE_URL %>/ajax/libs/axios/0.18.1/axios.min.js"></script>
    <script src="<%= VUE_APP_CDN_BASE_URL %>/ajax/libs/vuex/3.1.0/vuex.min.js"></script>
    <script src="<%= VUE_APP_CDN_BASE_URL %>/ajax/libs/vue-router/3.0.6/vue-router.min.js"></script>
    <script src="<%= VUE_APP_CDN_BASE_URL %>/ajax/libs/echarts/4.4.0/echarts.min.js"></script>
    <script src="<%= VUE_APP_CDN_BASE_URL %>/ajax/libs/Clamp.js/0.5.1/clamp.min.js"></script>
    <script src="<%= VUE_APP_CDN_BASE_URL %>/ajax/libs/moment.js/2.24.0/moment.min.js"></script>
    <script src="<%= VUE_APP_CDN_BASE_URL %>/ajax/libs/lodash.js/4.17.21/lodash.min.js"></script>


    模板語法配置可參考:??Vue CLI HTML 和靜態資源??


    修改完配置后,重啟開發環境

    經過這么一折騰,無論是開發環境還是生產環境,性能都有了極大的提升



    本文摘自 :https://blog.51cto.com/u

    開通會員,享受整站包年服務
    国产呦精品一区二区三区网站|久久www免费人咸|精品无码人妻一区二区|久99久热只有精品国产15|中文字幕亚洲无线码