我们以 vue-cli 工具为例,使用 vue-router 搭建SPA应用,UI框架选用 element-ui , ajax方案选用 axios, 并引入 vuex ,使用 vuex-router-sync 将 router 同步到 store ,服务器使用本地Nginx服务。

构建项目

vue-init webpack vue-spa-starter-kit
cd vue-spa-starter-kit
npm install
npm install vuex element-ui axios -S
npm run dev

vue-cli会自动打开浏览器,可以看到效果。我们在入口文件中引入vue-routerelement-uiaxios

// src/main.js
import 'babel-polyfill'
import Vue from 'vue' import App from './App' import axios from 'axios' import store from './store' import router from './router' import {sync} from 'vuex-router-sync' import ElementUI from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' Vue.config.productionTip = false Vue.use(ElementUI) Vue.prototype.$http = axios sync(store, router) /* eslint-disable no-new */ new Vue({ el: '#app', store, router, template: '<App/>', components: { App } }) 

接下来我们不做任何修改,使用默认的配置进行打包,Nginx采用默认配置,部署到Nginx,启动Nginx服务

可以看出,在没有开发任何页面及功能的情况下,vendor.js 有788kb。如果我们再依赖一些其他的库,比如 echarts 等,vendor.js 能到 1M 以上。

使用CDN资源

我们要将 vuevue-routervuexelement-uivendor.js 中分离出来,使用CDN资源引入。国内的CDN服务推荐使用 BootCDN。国外不是很好用。。。

  • 首先在模板文件index.html中添加以下内容:

    ...
    <head><link rel="stylesheet" href="https://cdn.bootcss.com/element-ui/2.0.7/theme-chalk/index.css"> </head> <body> <div id="app"></div> <script src="https://cdn.bootcss.com/vue/2.5.9/vue.min.js"></script> <script src="https://cdn.bootcss.com/vuex/3.0.1/vuex.min.js"></script> <script src="https://cdn.bootcss.com/vue-router/3.0.1/vue-router.min.js"></script> <script src="https://cdn.bootcss.com/element-ui/2.0.7/index.js"></script> <!-- built files will be auto injected --> </body> 
  • 修改 build/webpack.base.conf.js。关于 externals 配置项请自行查阅相关资料。

    module.exports = {...externals: {'vue': 'Vue','vuex': 'Vuex', 'vue-router': 'VueRouter', 'element-ui': 'ELEMENT' } ... } 
  • 修改 src/router/index.js

    // import Vue from 'vue'
    import VueRouter from 'vue-router'
    // 注释掉 // Vue.use(VueRouter) ... 
  • 修改 src/store/index.js

    ...
    // 注释掉
    // Vue.use(Vuex)
    ...
    
  • 修改 src/main.js

    import 'babel-polyfill'
    import Vue from 'vue' import App from './App' import axios from 'axios' import store from './store' import router from './router' import {sync} from 'vuex-router-sync' import ELEMENT from 'element-ui' // import 'element-ui/lib/theme-chalk/index.css' Vue.config.productionTip = false Vue.use(ELEMENT) Vue.prototype.$http = axios sync(store, router) /* eslint-disable no-new */ new Vue({ el: '#app', store, router, template: '<App/>', components: { App } }) 

    注意!这里 element-ui 变量名要使用 ELEMENT,因为element-ui的 umd 模块名是 ELEMENT

再次打包,部署到Nginx服务,可以看到:

vendor.js 减少到了 112kb,提升85.5%!

再看CDN资源,5个请求共216kb,耗时619ms!

Nginx 开启 gzip

vendor.js 我们优化完了,接下来我们优化服务器上的资源。先看看没有开启 gzip 的效果有 13.5kb

Nginx开启gzip,修改nginx配置文件 nginx.conf:

...

http {    ...

    gzip               on;    gzip_min_length    1k;    gzip_buffers       4  16k;    #gzip_http_version  1.1;    gzip_comp_level    2; # 压缩级别    # 要压缩的mine类型    gzip_types         text/plain application/javascript application/x-javascript text/javascript text/css application/xml application/xml+rss image/jpeg image/gif image/png image/svg+xml;    gzip_vary          off;    gzip_proxied       expired no-cache no-store private auth;    gzip_disable       "MSIE [1-6]\."; # IE6不支持gzip

    ...}

关于 nginx gzip,请自行查阅相关资料

重启nginx服务,可以看到服务器上的资源经过gzip压缩之后有 9kb,压缩比 13.3%。

development 和 production

上文中我们修改的是 build/webpack.base.conf.js,这样一来,本地开发的时候我们就不能使用 vue-devtools Chrome调试工具了,为了方便调试,我们需要将development和production 配置分开。

  1. 首先将 build/webpack.base.conf.jsexternals 配置项挪到 build/webpack.prod.conf.js 中:
// build/webpack.prod.conf.js
module.exports = {...externals: {'vue': 'Vue','vuex': 'Vuex', 'vue-router': 'VueRouter', 'element-ui': 'ELEMENT' } ... } 
  1. 拷贝 index.html 模板文件,并命名为 index.prod.html; 将原来的 index.html 重命名为 index.dev.html,并删除 CDN 资源:
<!-- index.dev.html -->
<head>...<!-- <link rel="stylesheet" href="https://cdn.bootcss.com/element-ui/2.0.7/theme-chalk/index.css"> -->
</head> <body> <div id="app"></div> <!-- <script src="https://cdn.bootcss.com/vue/2.5.9/vue.min.js"></script> <script src="https://cdn.bootcss.com/vuex/3.0.1/vuex.min.js"></script> <script src="https://cdn.bootcss.com/vue-router/3.0.1/vue-router.min.js"></script> <script src="https://cdn.bootcss.com/element-ui/2.0.7/index.js"></script> --> <!-- built files will be auto injected --> </body> <!-- index.prod.html --> <head> <link rel="stylesheet" href="https://cdn.bootcss.com/element-ui/2.0.7/theme-chalk/index.css"> </head> <body> <div id="app"></div> <script src="https://cdn.bootcss.com/vue/2.5.9/vue.min.js"></script> <script src="https://cdn.bootcss.com/vuex/3.0.1/vuex.min.js"></script> <script src="https://cdn.bootcss.com/vue-router/3.0.1/vue-router.min.js"></script> <script src="https://cdn.bootcss.com/element-ui/2.0.7/index.js"></script> <!-- built files will be auto injected --> </body> 
  1. 修改 build/webpack.dev.conf.js:
plugins: [...new HtmlWebpackPlugin({filename: 'index.html',template: 'index.dev.html',inject: true }) ] 
  1. 修改 build/webpack.prod.conf.js:
plugins: [...new HtmlWebpackPlugin({filename: 'index.html',template: 'index.prod.html',inject: true, ... }) ] 
  1. 修改 vue-routervuexelement-ui 的引用:
// src/main.js
...
if (process.env.NODE_ENV === 'development') {require('element-ui/lib/theme-chalk/index.css')
}
...// src/router/index.js import Vue from 'vue' import VueRouter from 'vue-router' if (process.env.NODE_ENV === 'development') { Vue.use(VueRouter) } ... // src/store/index.js import Vue from 'vue' import Vuex from 'vuex' if (process.env.NODE_ENV === 'development') { Vue.use(Vuex) } ... 

这样我们就可以愉快的在开发环境使用 vue-devtools Chrome调试工具了!

vue.js 首屏优化相关推荐

  1. vue项目的首屏优化策略

    虽然标题是vue项目的首屏优化策略,但是里面绝大部分的方法,对于其他语言写成的单页应用同样适用 1.使用路由懒加载 首屏进入时,直接加载和首屏相关路由,其他全部路由组件实现懒加载,即打开该路由时再去加 ...

  2. 移动spa商城优化记(一)---首屏优化篇

    背景 随着公司业务的不断壮大,最近老是有用户反应公司APP内的商城打开比较慢,这可不行啊,慢了容易流失用户,流失用户减少公司业绩,公司业绩少我的年终奖就少----,所以为了公司,也为了自己,开始优化之 ...

  3. 时间都去哪了-移动Web首屏优化实践

    时间都去哪了-移动Web首屏优化实践 首屏时间 可用性的前提,后面用户是否使用你app很重要的因素之一: 我们PC上访问其实现在的带宽已经很好了,百兆光宽带,但是在移动端就不一样了,很多用户还是使用的 ...

  4. [vue] SPA首屏加载速度慢的怎么解决?

    [vue] SPA首屏加载速度慢的怎么解决? 1.通过Gzip压缩 2.使用路由懒加载 3.利用webpack中的externals这个属性把打包后不需要打包的库文件都分离出去,减小项目打包后的大小 ...

  5. 【前端面试】首屏优化

    [前端面试]首屏优化 多一些不为什么的坚持

  6. Vue.js 应用性能优化,给你专业的分析+解决方案

    目录 介绍 为什么我们需要 Vue JS 性能优化? Vue 性能不佳背后的主要原因 如何检查您的 VueJS 应用的大小? 如何优化 Vue js 应用程序的性能? 1. 在 Vue js 中懒加载 ...

  7. 10个技巧!实现Vue.js极致性能优化(建议收藏)

    导语 | Vue是一套用于构建用户界面的渐进式的JavaScript框架.它具有体积小,更高的运行效率,双向数据绑定,生态丰富.学习成本低等优点,所以Vue也被广泛用在移动端跨平台框架上.接下来,我将 ...

  8. html页面数字滚动,Vue.js大屏可视化数据数字滚动翻转跳转效果(通俗易懂附完整代码)...

    原文:Vue.js大屏可视化数据数字滚动翻转跳转效果(通俗易懂附完整代码) 大屏数字滚动翻转效果来源于最近工作中element后台管理页面一张大屏的UI图,该UI图上有一个模块需要有数字往上翻动的效果 ...

  9. Vue 单页应用 的 首屏优化

    对于单页应用,要在一个页面上为用户提供产品的所有功能,在这个页面加载的时候,首先要加载大量的静态资源,这个加载时间相对比较长.所以我们需要做一些相应的优化,减少响应时间,尽快把首屏显示出来. 1.压缩 ...

  10. vue项目首屏加载优化

    1.将第三方资源使用cdn引入 将项目中用到的一些第三方库通过cdn的方式引入的话,在打包的时候就不需要对第三方库进行打包,自然就减小了包的大小,首屏加载的时候所加载的内容也就减少了,加载时间就少了. ...

最新文章

  1. CSS中块级格式化上下文(BFC)的特性与应用
  2. UA PHYS515 电磁理论I 麦克斯韦方程组基础1 库仑定律与毕奥-萨伐尔定律
  3. php 二维数组值相加,php二维数组指定某元素后面的值是和前面的值相加起来的...
  4. Android Monkey的使用
  5. Mysql 的表级锁和行级锁
  6. 【编译原理】入门总结
  7. !DOCTYPE 标签是什么
  8. 500 内部服务器错误php,如何解决php 500 - 内部服务器错误
  9. github 搜索_如何通过GitHub快速的搜索资源?
  10. android最简单的更换主题,教你更换Android手机主题
  11. 萤火虫算法_第二十二章 萤火虫算法(Firefly Algorithm,FA)补充和答疑
  12. matlab求两向量夹角_向量法解几何问题
  13. HTML标记由尖括号和,HTML标记
  14. Python对word文档进行操作
  15. MRCP协议学习笔记
  16. python对数正态分布函数_Lognormal Distribution对数正态分布
  17. react native Animated 使用详解(基础)
  18. Caysn打印机安卓平台开发包接口说明文档及打印示例程序_20170609
  19. 类与对象(一)----什么是类和对象
  20. 解决:WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING

热门文章

  1. matlab 找椭圆中心点,点差分法matlab解椭圆型偏微分方程
  2. MAC编译jogl/gluegen很顺利
  3. 难以置信:产品图标是黑色背景
  4. dpkg: 错误: 另外一个进程已经为 dpkg frontend lock 加锁
  5. 韩国李世石跟韩国AI大战,2负一胜
  6. VS中编辑器显示行号
  7. VS中,一个头文件使用另外一个头文件的静态变量,要谨慎
  8. 热的感觉是顺经络走的
  9. 隋朝之前,扬州指的是现在的南京
  10. 听说杭州湾大桥因为影响候鸟迁徙被抗议