位置: IT常识 - 正文

Vue首屏加载过慢出现白屏的六种优化方案(vue加载速度慢)

编辑:rootadmin
Vue首屏加载过慢出现白屏的六种优化方案

推荐整理分享Vue首屏加载过慢出现白屏的六种优化方案(vue加载速度慢),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue首屏加载慢的原因,vue如何优化首屏加载速度,vue第一次打开慢,vue如何优化首屏加载速度,vue解决首屏加载慢,vue如何优化首屏加载速度,vue如何优化首屏加载速度,vue解决首屏加载慢,内容如对您有帮助,希望把文章链接给更多的朋友!

公司业务展示官网开发,构建版本后在测试环境下,发下首屏加载损耗高达几十秒(服务器在国外,所以也导致加载时间变长),于是采用了以下方法来达到提速目的。 

1. 采用懒加载的方式

路由懒加载和组件懒加载:const One = ()=>import("./one");

图片懒加载:使用vue-lazyload插件

//引入vue懒加载import VueLazyload from 'vue-lazyload'//方法一: 没有页面加载中的图片和页面图片加载错误的图片显示// Vue.use(VueLazyload)//方法二: 显示页面图片加载中的图片和页面图片加载错误的图片//引入图片import loading from '@/assets/images/load.jpg'//注册图片懒加载 Vue.use(VueLazyload, { // preLoad: 1.3, error: '@/assets/images/error.jpg',//图片错误的替换图片路径(可以使用变量存储) loading: loading,//正在加载的图片路径(可以使用变量存储) // attempt: 1})2.webpack开启gzip压缩文件传输模式

gizp压缩是一种http请求优化方式,通过减少文件体积来提高加载速度。html、js、css文件甚至json数据都可以用它压缩,可以减小60%以上的体积。

 webpack打包时借助 compression webpack plugin实现gzip压缩,安装插件如下:npm i -D compression-webpack-plugin

Vue首屏加载过慢出现白屏的六种优化方案(vue加载速度慢)

在vue-cli 3.0 中,vue.config.js配置如下:

const CompressionPlugin = require('compression-webpack-plugin');//引入gzip压缩插件module.exports = { plugins:[ new CompressionPlugin({//gzip压缩配置 test:/\.js$|\.html$|\.css/,//匹配文件名 threshold:10240,//对超过10kb的数据进行压缩 deleteOriginalAssets:false,//是否删除原文件 }) ]}

服务器nginx开启gzip:

 

3.依赖模块采用第三方cdn资源 

修改vue.config.js

module.exports = { ... externals: { 'vue': 'Vue', 'vuex': 'Vuex', 'vue-router': 'VueRouter', 'element-ui': 'ELEMENT' } ...}4.禁止生成map文件

在vue.config.js配置:

module.exports = { productionSourceMap: false, // 生产环境是否生成 sourceMap 文件,一般情况不建议打开}

在设置了productionSourceMap: false之后,就不会生成map文件,map文件的作用在于:项目打包后,代码都是经过压缩加密的,如果运行时报错,输出的错误信息无法准确得知是哪里的代码报错。也就是说map文件相当于是查看源码的一个东西。如果不需要定位问题,并且不想被看到源码,就把productionSourceMap 置为false,既可以减少包大小,也可以加密源码。

5.去掉代码中的console和debugger

打包之后控制台很干净,部署正式环境之前最好这样做。

configureWebpack: config => { if (process.env.NODE_ENV === 'production') { config.optimization.minimizer[0].options.terserOptions.compress.warnings = false config.optimization.minimizer[0].options.terserOptions.compress.drop_console = true config.optimization.minimizer[0].options.terserOptions.compress.drop_debugger = true config.optimization.minimizer[0].options.terserOptions.compress.pure_funcs = ['console.log'] } },6. 预渲染配置

使用插件:prerender-spa-plugin 

vue.config.js中配置如下:

const PrerenderSpaPlugin = require('prerender-spa-plugin');const Render = PrerenderSpaPlugin.PuppeteerRenderer;const path = require('path');configureWebpack: () => { if (process.env.NODE_ENV !== 'production') return; return { plugins: [ new PrerenderSPAPlugin({ // 生成文件的路径,也可以与webpakc打包的一致。 // 下面这句话非常重要!!! // 这个目录只能有一级,如果目录层次大于一级,在生成的时候不会有任何错误提示,在预渲染的时候只会卡着不动。 staticDir: path.join(__dirname, 'dist'), // 对应自己的路由文件,比如a有参数,就需要写成 /a/param1。 routes: ['/', '/Login', '/Home'], // 这个很重要,如果没有配置这段,也不会进行预编译 renderer: new Renderer({ inject: { foo: 'bar' }, headless: false, // 在 main.js 中 document.dispatchEvent(new Event('render-event')),两者的事件名称要对应上。 renderAfterDocumentEvent: 'render-event' }) }) ] };}
本文链接地址:https://www.jiuchutong.com/zhishi/297569.html 转载请保留说明!

上一篇:Vue组件滚动加载、懒加载功能的实现,无限滚动加载组件实例演示(vue组件元素设置滚动条高度)

下一篇:手把手教你训练一个VAE生成模型一生成手写数字(你知道怎么训练)

  • ipad pro分屏功能怎么用(ipadpro分屏功能怎么开启)

    ipad pro分屏功能怎么用(ipadpro分屏功能怎么开启)

  • iphone13安装软件需要按两下(iphone13安装软件每次都要输入密码)

    iphone13安装软件需要按两下(iphone13安装软件每次都要输入密码)

  • 支付宝注销了能再注册吗(支付宝注销了能查到账单吗)

    支付宝注销了能再注册吗(支付宝注销了能查到账单吗)

  • 申请退款了怎么卖家还发货怎么办(申请退款了怎么拒收快递)

    申请退款了怎么卖家还发货怎么办(申请退款了怎么拒收快递)

  • l1l2l开关怎么接(l1l2l开关怎么接带插座)

    l1l2l开关怎么接(l1l2l开关怎么接带插座)

  • 优酷视频会员怎么分享给别人(优酷视频会员怎么分享给别人用)

    优酷视频会员怎么分享给别人(优酷视频会员怎么分享给别人用)

  • p40是不是双卡(p40是不是双卡的)

    p40是不是双卡(p40是不是双卡的)

  • 垃圾短信怎么拦截不住(垃圾短信怎么拦截能收不到?)

    垃圾短信怎么拦截不住(垃圾短信怎么拦截能收不到?)

  • 网线亮橙灯是什么意思(网线灯橙色闪烁怎么回事?)

    网线亮橙灯是什么意思(网线灯橙色闪烁怎么回事?)

  • qq群宣传委员怎么获得(qq群宣传委员头衔怎么分享了没有)

    qq群宣传委员怎么获得(qq群宣传委员头衔怎么分享了没有)

  • qq为什么不能匹配聊天(我的qq突然就不能匹配了)

    qq为什么不能匹配聊天(我的qq突然就不能匹配了)

  • 7p重量多少克(iphone 7p重量是多少克)

    7p重量多少克(iphone 7p重量是多少克)

  • 抖音上超级乐迷是什么(抖音上超级乐迷什么意思)

    抖音上超级乐迷是什么(抖音上超级乐迷什么意思)

  • 视频线红白黄代表什么(视频线红白代表什么)

    视频线红白黄代表什么(视频线红白代表什么)

  • 华为mate30息屏显示费电吗

    华为mate30息屏显示费电吗

  • 全民k歌怎么提现(全民k歌怎么提现到微信)

    全民k歌怎么提现(全民k歌怎么提现到微信)

  • iphone应用数据备份(苹果应用程序备份)

    iphone应用数据备份(苹果应用程序备份)

  • 探探超级喜欢什么用(探探超级喜欢什么意思)

    探探超级喜欢什么用(探探超级喜欢什么意思)

  • 删除文档中的所有全角空格(删除文档中的所有批注)

    删除文档中的所有全角空格(删除文档中的所有批注)

  • 苹果手机无线充电设置在哪里(苹果手机无线充电功能)

    苹果手机无线充电设置在哪里(苹果手机无线充电功能)

  • 电子三包凭证能换屏吗(电子三包凭证能确定平板是新的吗)

    电子三包凭证能换屏吗(电子三包凭证能确定平板是新的吗)

  • Win10登录总是提示密码已过期必须更改该怎么办?(windows登录提示)

    Win10登录总是提示密码已过期必须更改该怎么办?(windows登录提示)

  • manager.exe是什么进程 有什么用 manager进程查询(manager's office是什么意思)

    manager.exe是什么进程 有什么用 manager进程查询(manager's office是什么意思)

  • 留底退税怎么做账务处理
  • 人民币报关可以吗
  • 质量扣款能按折扣计算吗
  • 税额和税款的区别
  • 增值税多提了怎么处理
  • 免税是不是不用交税
  • 外贸公司报关员是干什么的
  • 核定征收企业股权转让所得税
  • 建筑企业收到预售款时需要缴纳增值税吗
  • 个人独资企业的债务由谁承担
  • 个体户要交国税和地税吗
  • 事业单位乱报销出纳怎么办?
  • 零申报有期限吗
  • 7.1发票没有税号怎么开
  • 2016年红冲发票流程
  • 基建人员工资计入哪个科目
  • 所得税费用按月还是按年算
  • 耕地占用税与土地出让金
  • 资产减值准备如何转销
  • 城市维护建设税属于什么税种
  • 什么是民政福利企业
  • 电子承兑如何转出换成现金
  • 管理费用与税金的比例
  • 苹果电脑快捷键删除
  • 存货跌价准备怎么理解
  • 公司收到项目的现金
  • 无法找到脚本文件vbs
  • 收到政府补贴的装修款
  • sudo命令无法执行
  • 收到过期银行汇票怎么办
  • 金税盘不能清卡的原因
  • 税务局开出来的发票没问题吧?
  • centos安装php环境
  • yii2中dropDownList实现二级和三级联动写法
  • vue二级菜单的隐藏与显示
  • php怎么将数据库中的数据显示出来
  • 发票其他服务费包括哪些
  • 一个用于表示特定的web页的标识符url称为
  • 狗能看懂的电视
  • un删除
  • look 查明
  • C语言中指针变量指向字符串时是有效字符的长度吗
  • 建筑业增值税怎么算举例说明
  • 商品流通企业库存商品的核算方法有以下几种
  • python异常值处理方法
  • access创建一个表
  • vue前端页面设计
  • 年金终值系数表值系数
  • 劳务报酬所得与工资薪金所得纳税的区别
  • 个体户开票超额
  • 企业计提固定资产折旧以什么假设为前提
  • 印花税的征收方式有哪些
  • 房屋出租后转租缴纳房产税吗
  • 咨询费放到什么科目
  • 安置房买卖过户流程
  • 新会计准则适用企业
  • 回购股票并注销是利好吗
  • 外贸企业需要取得什么资质
  • 残疾人就业保障金征收使用管理办法
  • 短期借款利息是多少
  • 存货总账根据什么填列
  • centos 6.6安装教程
  • ubuntu安装office2019
  • 苹果发布会最新消息
  • linux如何修改gid
  • camrec是什么文件
  • SchSvr.exe - SchSvr是什么进程 有什么作用
  • win10系统中断怎么解除
  • windows alt r
  • ,linux
  • Node.js中的核心模块包括哪些内容?
  • linux怎么查看tomcat位置
  • 请不要重复犯我在学习Python和Linux系统上的错误
  • python jsonp
  • python安装后怎么用
  • time模块 python
  • 社保已申报怎么停止缴费
  • 北京国家税务局总局官网
  • 税务之星ii驱动
  • 国网成都市局和绵阳市局的区别?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设