一次vue项目优化的实际操作记录

前言

项目前端优化是我们经常需要去做的事情,今天我们就来记录下我的实际操作。

一、CDN引入

这是一个常态化的操作了,主要是让我们通过npm下载依赖包和import引入的文件,变成线上使用,减少打包后的文件大小。比如常用的vue、ElementUI、vuex、vue-router、axios等等一些常用的

首先在index.html文件引入

    
    
    
     
    
    
    

然后注释掉import引入的

一次vue项目优化的实际操作记录_第1张图片

一定要把Vue.use(ElementUI)注释

第三步,找到webpack.base.conf.js文件,在下面添加你CDN引入的依赖

一次vue项目优化的实际操作记录_第2张图片

vuex的store/store.js文件里面修改

一次vue项目优化的实际操作记录_第3张图片

router文件也需要修改

一次vue项目优化的实际操作记录_第4张图片

坑:

1.一定要先引入vue的,然后再加其他的,不然会报错,找不到elementUI的标签名;

2.不能只引入elementUI,不引入vue,一样会报错;

3.我引入的vue-routerCDN,在抓包的时候发现居然要四点多秒种才下载完成,所以我就去掉了,我不知道你们会不会,可以先试试。

二、gzip压缩

首先安装一个插件

npm install --save-dev compression-webpack-plugin

然后在config/index.js里面开启

一次vue项目优化的实际操作记录_第5张图片

然后在webpack.prod.conf.js,找到这段代码

一次vue项目优化的实际操作记录_第6张图片

最后就是后端配置的问题

浏览器查看请求头,有下面这些标志就是开启成功了

一次vue项目优化的实际操作记录_第7张图片

三、路由懒加载,这种最简单的了就不多说了

const production = () => import('@/components/view/production/production')
​
{
    name: '123123',
    path: 'production',
    component: production
  },

四、打包不生成map文件

config/index.js
​
productionSourceMap: false,

五、router上面使用props传参数,导致页面加载时间很长

我在优化一个项目的时候,里面有一个单点登陆的功能页面。这个需要通过路由传参数,但是在首次进入页面的时候,浏览器捉包发现第一次请求的时候,打包的css一直被挂载长达将近20秒。

从发现这个问题开始,我一直以为是因为css文件太多,但是也就四百多kb,但是也对css文件进行各种的优化,拆分、减少背景图片的引入等等,甚至使用了CDN引入了某些css文件,减少到两百多kb最后还是一样的问题,就觉得不是这个问题。

最后我们测试,正常打开登陆页面然后进入页面,是正常的不会挂载。但是使用单点登陆就会挂载,然后就去一个测试检测,最后发现,只要把传参模式修改了,就正常了!!!!!!!!!!!!!!!!!!!!!!!!!!!

优化前的传参,使用了props

{
      name: 'Login',
      path: '/Login',
      component: Login,
      props: (route) => ({username: route.query.username})
},

优化后的参数,直接拼在路径后面

{
      name: 'Login',
      path: '/Login/:username',
      component: Login,
      // props: (route) => ({username: route.query.username})
},

我是真的栓q!

一次vue项目优化的实际操作记录_第8张图片

总结

到此这篇关于vue项目优化的文章就介绍到这了,更多相关vue项目优化内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的:(一次vue项目优化的实际操作记录)