Vue.js项目加载速度性能优化

简介: Vue.js项目加载速度性能优化

随着项目引入的依赖增多,每次打开项目,无论是开发环境还是生产环境,都逐步变慢。开始没有感觉不明显,随着项目迭代次数增多,网站打开速度有了明显的卡顿感。


外部第三方依赖,一般都是固定的版本,不会随着项目进行而改变,可以利用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>

相关文章
|
22天前
|
前端开发 JavaScript Java
【03】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架搭建-服务端-后台管理-整体搭建-优雅草卓伊凡商业项目实战
【03】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架搭建-服务端-后台管理-整体搭建-优雅草卓伊凡商业项目实战
96 13
【03】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架搭建-服务端-后台管理-整体搭建-优雅草卓伊凡商业项目实战
|
23天前
|
人工智能 JavaScript 关系型数据库
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
83 14
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
|
21天前
|
SQL JavaScript 安全
【04】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架二次开发准备工作-以及建立初步后端目录菜单列-优雅草卓伊凡商业项目实战
【04】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架二次开发准备工作-以及建立初步后端目录菜单列-优雅草卓伊凡商业项目实战
69 11
【04】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架二次开发准备工作-以及建立初步后端目录菜单列-优雅草卓伊凡商业项目实战
|
25天前
|
人工智能 JavaScript 安全
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
86 13
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
|
24天前
|
监控 JavaScript 前端开发
ry-vue-flowable-xg:震撼来袭!这款基于 Vue 和 Flowable 的企业级工程项目管理项目,你绝不能错过
基于 Vue 和 Flowable 的企业级工程项目管理平台,免费开源且高度定制化。它覆盖投标管理、进度控制、财务核算等全流程需求,提供流程设计、部署、监控和任务管理等功能,适用于企业办公、生产制造、金融服务等多个场景,助力企业提升效率与竞争力。
83 12
|
2月前
|
资源调度 JavaScript 前端开发
创建vue3项目步骤以及安装第三方插件步骤【保姆级教程】
这是一篇关于创建Vue项目的详细指南,涵盖从环境搭建到项目部署的全过程。
224 1
|
4月前
|
数据采集 监控 JavaScript
在 Vue 项目中使用预渲染技术
【10月更文挑战第23天】在 Vue 项目中使用预渲染技术是提升 SEO 效果的有效途径之一。通过选择合适的预渲染工具,正确配置和运行预渲染操作,结合其他 SEO 策略,可以实现更好的搜索引擎优化效果。同时,需要不断地监控和优化预渲染效果,以适应不断变化的搜索引擎环境和用户需求。
|
4月前
|
缓存 JavaScript 前端开发
掌握现代JavaScript异步编程:Promises、Async/Await与性能优化
本文深入探讨了现代JavaScript异步编程的核心概念,包括Promises和Async/Await的使用方法、最佳实践及其在性能优化中的应用,通过实例讲解了如何高效地进行异步操作,提高代码质量和应用性能。
|
4月前
|
JavaScript 前端开发
如何在 Vue 项目中配置 Tree Shaking?
通过以上针对 Webpack 或 Rollup 的配置方法,就可以在 Vue 项目中有效地启用 Tree Shaking,从而优化项目的打包体积,提高项目的性能和加载速度。在实际配置过程中,需要根据项目的具体情况和需求,对配置进行适当的调整和优化。
|
4月前
|
缓存 监控 JavaScript
Vue.js 框架下的性能优化策略与实践
Vue.js 框架下的性能优化策略与实践

热门文章

最新文章