vue.js 首屏优化
我们以 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-router、element-ui、axios
// 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资源
我们要将 vue、 vue-router、 vuex、element-ui 从 vendor.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 配置分开。
- 首先将 build/webpack.base.conf.js中externals配置项挪到build/webpack.prod.conf.js中:
// build/webpack.prod.conf.js
module.exports = {
  ...
  externals: {
    'vue': 'Vue',
    'vuex': 'Vuex',
    'vue-router': 'VueRouter',
    'element-ui': 'ELEMENT'
  }
  ...
}
- 拷贝 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>
- 修改 build/webpack.dev.conf.js:
plugins: [
  ...
  new HtmlWebpackPlugin({
    filename: 'index.html',
    template: 'index.dev.html',
    inject: true
  })
]
- 修改 build/webpack.prod.conf.js:
plugins: [
  ...
  new HtmlWebpackPlugin({
    filename: 'index.html',
    template: 'index.prod.html',
    inject: true,
    ...
  })
]
- 修改 vue-router、vuex、element-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 首屏优化的更多相关文章
- vue项目首屏加载优化实战
		问题 单页面应用的一个问题就是首页加载东西过多,加载时间过长.特别在移动端,单页面应用的首屏加载优化更是绕不开的话题.下面我会写出我在项目中做的一些优化,希望大家能够相互讨论,共同进步. 我的项目vu ... 
- Vue SPA 首屏加载优化实践
		写在前面 本文记录笔者在Vue SPA项目首屏加载优化过程中遇到的一些坑及优化方案! 我们以 vue-cli 工具为例,使用 vue-router 搭建SPA应用,UI框架选用 element-ui ... 
- Vue 单页应用 的 首屏优化
		对于单页应用,要在一个页面上为用户提供产品的所有功能,在这个页面加载的时候,首先要加载大量的静态资源,这个加载时间相对比较长.所以我们需要做一些相应的优化,减少响应时间,尽快把首屏显示出来. 1.压缩 ... 
- angular 首屏优化
		前一段时间把公司的一个angular项目做了一次大的优化,记录一下过程. 起因: 起因是用户反映网站加载时间过长,从loading画面显示到页面可响应要13s,对于一般的页面恐怕没有用户愿意等待这么久 ... 
- vue目首屏添加skeleton骨架屏
		1. 安装插件:npm install vue-skeleton-webpack-plugin 2. 在src目录下创建 Skeleton.vue <template> <div c ... 
- vue客户端渲染首屏优化之道
		提取第三方库,缓存,减少打包体积 1. dll动态链接库, 使用DllPlugin DllReferencePlugin,将第三方库提取出来另外打包出来,然后动态引入html.可以提高打包速度和缓存第 ... 
- Vue.js大屏数字滚动翻转效果
		================================ 大屏数字滚动翻转效果来源于最近工作中element后台管理页面一张大屏的UI图,该UI图上有一个模块需要有数字往上翻动的效果,以下是最 ... 
- vue实现首屏加载等待动画 避免首次加载白屏尴尬
		0 直接上效果图 1背景,用户体验良好一直是个重要的问题. 2怎么加到自己项目里面? 复制css html代码到自己的index.html即可 代码链接 源码地址 Vue学习前端群493671066, ... 
- react 首屏性能优化
		首屏优化点:1.加载包(bundle.js)文件的大小,越小,首屏渲染速度越快 (按需加载) 2.优先渲染用户直观看到的页面部分(懒加载) 技术点:react-loadable . react-laz ... 
随机推荐
- DUBBO本地搭建及小案例 (转)
			DUBBO的介绍部分我这里就不介绍了,大家可参考官方文档. DUBBO的注册中心安装 DUBBO的注册中心支持好几种,公司用到zookeeper注册中心,所以我这边只说明zookeeper注册中心如何 ... 
- RHEL7 光盘修复
			光盘修复#rm -rf /boot/*#dd if=/dev/zero of=/dev/sda bs=446 count=1#systemctl rebootTroubleshooting(排错模式) ... 
- 分布式交易系统的并发处理, 以及用Redis和Zookeeper实现分布式锁
			交易系统 交易系统的数据结构 支付系统API通常需要一个“订单号”作为入参, 而实际调用API接口时使用到的往往不是真正意义的业务订单号, 而是交易订单号. 支付系统的API会使用“商户号+订单号” ... 
- Delphi单元文件引用名称问题
			Delphi新版本的单元文件格式变化了,如windows变成了winapi.windows,如果想在单元引用中使用简称,则需要在工程选项中配置: 这样就可以使用全名或简写来引用单元了. 
- java+win7+eclipse+Maven+sikuli 配置总结---图形脚本语言
			简介:Sikuli 是一种新颖的图形脚本语言,或者说是一种另类的自动化测试技术.它与我们常用的自动化测试技术(工具)有很大的区别. 关于配置,一直是一个问题,下面做个总体介绍,用sikuli也有几个月 ... 
- [Spring学习笔记 3 ]  spring 注解详解,完全注解,常用注解
			.xml使用注解 xml 用来定义bean的信息,注解用来配置依赖信息 ) 在配置文件中配置bean )在javaBean中用注解来指定依赖注入 )在配置文件中开启注解扫描 @Resource标签 j ... 
- NSOperation, NSOperationQueue 原理探析
			通过GNUstep的Foundation来尝试探索下NSOperation,NSOperationQueue 示例程序 写一个简单的程序 - (void)viewDidLoad { [super vi ... 
- Win7 U盘安装Ubuntu16.04 双系统详细教程(方法一)
			主要分为以下几步: 一. 下载Ubuntu 16.04镜像软件: 二. 制作U盘启动盘使用ultraISO: 三. 安装Ubuntu系统: 四. 用EasyBCD 创建启动系统启动引导: (根据个人情 ... 
- linux达人养成计划学习笔记(一)——命令基本格式及文件处理命令
			一.shell终端初始 快捷键Ctrl + Alt + T,可以快速打开终端 bluemoutain 当前用户名 bluemoutain-CN155 本机名 ~ 当前目录(家目录,root用户为/ro ... 
- Red Hat忘记root密码了怎么办?
			方法很简单: 在出现grub画面时,用上下键选中平时启动linux的那一项,然后按a键,可以进行append模式 在出来的命令行等方面加上 空格 single , 这样可以进入单用户模式,再 pass ... 
