vue优化小技巧

记录一下我自己优化vue项目的一些小方法

图片优化

  • 一般切完图后我会把图片压缩一次,这样可以减小图片的体积,压缩工具我用得是这个 https://tinypng.com/,免费的,而且压缩完分辨率也跟原来差不多,视觉上不会有太大的影响。

  • 一些小图标,做成雪碧图能减少图片请求数据,建议只把那些固定的,后期不会修改的图标做成雪碧图,如果是那些要经常改动的就不建议这么做发,因为一旦要修改就连其它地方也要修改了,如果项目比较复杂的话可能连自己都忘了要改哪里了。

  • 图片做懒加载处理,我用的是 vue-lazyload 插件,使用方法如下:

    安装:yarn add vue-lazyload

    在入口文件中引入:

    import VueLazyload from "vue-lazyload";
    
    Vue.use(VueLazyload);
    

    然后只需要把图片的 src 改为 v-lazy 就行了,注意 imgUrl 是图片的http路径,如果是本地的图片路径则需要处理下,比如先用 require() 的方式引入再赋值

    <img v-lazy="imgUrl" />
    

首屏优化

用vue项目有个特点就是一进入页面会有一段时间的白屏,给人的体验非常差,网上也有很多方案,不过大多都是说什么模块按需加载,开启gzip压缩,服务端渲染(ssr),服务端渲染还算靠谱,前面那两种只能加快页面加载速度,还是无法解决刚进入页面的白屏情况的,原因是因为模板文件 index.html 里有如下的一个标签

<div id="app"></div>

当我们把项目打包后一般就是如上所示,页面加载时首先展示的是这个,当js和css加载完成后再把这个标签替换成我们本来的页面内容,所以在替换的这个过程中就会产生一段时间的白屏,如果遇上网络慢的情况会更加明显。无论你的代码压缩到多少,分了多少模块,还是会出现白屏的。

归根到底就是页面一开始加载的时候没有内容,如果页面一进来 <div id="app"></div> 里就有内容的话就不会产生白屏的效果了,我的做法是将第一屏的结构样式先写到 <div id="app"></div> 里,如下所示:

<div id="app">
    <div style="width:100%;height:450px;background:url('../src/assets/header_sm.jpg') no-repeat;background-color:#d81f25;background-position:top;">
      <div style="position:relative;width:1056px;height:440px;margin:0 auto;">
        <a target="_blank" style="display: block;width: 122px;height: 32px;background: url(../src/assets/logo.png);background-repeat: no-repeat;background-size: 100% 100%;position: absolute;top: 21px;left: 115px;"></a>
      </div>
    </div>
    <div style="width:100%;position:relative;background-color:#d81f25;">
      <div style="-webkit-box-sizing: border-box;width: 1058px;margin: 0 auto;height: 100%;background-color: #fbe9cf;position: relative;box-sizing: border-box;height: 577px;padding: 20px 0 11px 20px;">
        <div style="float: left;width: 728px;">
          <div style="background: #fae588;border: 10px solid #fae588;-webkit-box-sizing: border-box;box-sizing: border-box;height: 396px;"></div>
        </div>
      </div>
    </div>
  </div>

这样一进入页面首先看到的就是首屏的静态内容了,当页面加载完成后就会替换成正式内容,给人一种视觉上的误差,就不会产生白屏的情况了,体验上也会好一点

还有一种方案是在 <div id="app"></div> 写一个加载中的动画,这样看起来也会好一点,比较适合用在移动端。

网上还有另一种方案是预渲染方案,需要用到 prerender-spa-plugin 这个插件,其实原理都差不多,都是在页面开始加载时让页面有内容,具体可以看 https://blog.csdn.net/huangjianfeng21/article/details/92421738,我照着文章那样配置完在打包时老是报这个错误 Chromium revision is not downloaded. Failed to download Chromium 网上的方法都试过了还是失败,Chromium各个版本都试过了也不行,都不知道具体是什么原因。

使用Toast弹窗美化提示

在提交表单时经常会用到弹窗提示,如果设计稿没有做的话我们就要自己做了,单纯的使用 alert() 的话给人的感觉不是很好,所以我们可以自己封装一个toast组件,具体做法参考 https://www.jianshu.com/p/0891ae3a7e6d 我也是按照这篇文章来写的,不过这里有个地方需要修改下,


let ifhadToast = false;

function showToast(msg, duration = 1500) {
    if(ifhadToast) {
        return ;
    }
    
    ifhadToast = true;

    ...
}

加这个主要是防止连续点击造成toast连续出现的情况,加了之后就不会出现这种情况了,只会等上一次toast执行完之后才会继续弹出。

总结

无论何时项目优化都是需要我们关注的一个点,从用户角度来看,用户体验决定了这个项目是否是一个优秀的项目,作为前端,不仅要关注业务逻辑,还要时刻关注用户体验,哪怕是一些不起眼的地方也值得我们去优化。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,294评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,493评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,790评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,595评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,718评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,906评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,053评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,797评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,250评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,570评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,711评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,388评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,018评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,796评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,023评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,461评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,595评论 2 350

推荐阅读更多精彩内容

  • 基于Vue的一些资料 内容 UI组件 开发框架 实用库 服务端 辅助工具 应用实例 Demo示例 element★...
    尝了又尝阅读 1,142评论 0 1
  • UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 m...
    柴东啊阅读 15,849评论 2 140
  • UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 m...
    随行者pgl阅读 3,307评论 0 15
  • UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 m...
    小姜先森o0O阅读 9,417评论 0 72
  • UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 m...
    流觞小菜鸟阅读 1,751评论 2 8