码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 前端培训丁鹿学堂:vue性能优化总结(二)


    在函数中,变量本地化

    其实就是在vue的方法中,如果用到了data中的数据,合适的情况下,先用本地变量保存,操作处理数据以后,直接return返回出去。
    原理是,每次访问 this.xx 的时候,由于是响应式对象,所以每次都会触发 getter,然后执行依赖收集的相关代码,如果使用变量次数越多,性能就会变差。
    示例代码:

    export default {
      data(){
        return {
          num:10
        }
      },
      methods:{
        add(){
          let number = this.number // 保存起来    
          for (let i = 0; i < 500; i++) {   
            number += i // 避免频繁引用this.xx   
          }   
          return number 
        }
      }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    按需引入第三方插件

    比如 Element-UI ,vantUI这样的第三方组件库可以按需引入避免体积太大。

    路由使用懒加载

    这个属于首屏优化的部分。 Vue 是单页面应用,所以如果没有使用懒加载的话,就会导致进入首页时需要加载的内容过多,时间过长,就会出现长时间的白屏,很不利于用户体验,SEO 也不友好
    所以可以去用懒加载将页面进行划分,需要的时候才加载对应的页面,以分担首页的加载压力,减少首页加载时间。

    
    const router = new VueRouter({
      routes: [ 
         { path: '/home', component: () => 
        import('@/components/Home') }, 
      ]
    })
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    在进入这个路由的时候才会走对应的 component,然后运行 import 编译加载组件

    使用keep-alive缓存组件

    常见的应用场景是:用户填写表单,输入页面进入下一步后,再返回上一步到表单页时要保留表单输入的内容。
    我们都可以通过内置组件 来把组件缓存起来,在组件切换的时候不进行卸载,这样当再次返回的时候,就能从缓存中快速渲染,而不是重新渲染,以节省性能。另外对用户体验也非常友好。
    代码示例:

    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    注意点:

    1. 可以在路由配置的页面指定是否缓存该路由对应的页面组件。
    2. 可以通过两个生命周期 activated/deactivated 来获取当前组件状态。
    小结:

    其实在vue开发过程中还有很多的性能优化技巧,比如图片懒加载,无状态的组件通过函数式去书写。但是常见的,比较适合新手的一些性能优化技巧就是上面的内容。
    希望大家在开发 过程中有意识的去使用这些技巧,让自己的代码越来越完美。

  • 相关阅读:
    DDD学习笔记
    asp.net docker-compose添加kafka和redis和zookeeper
    网安周报|Chaes恶意软件的新Python变种针对银行和物流行业
    【ceph】ceph集群的节点机器重启,导致磁盘的lvm消失,如何恢复呢~~满满的都是干货
    国际阿里云服务器到期多久会释放资源信息?
    上海钢联朱军红:产业互联网的“双创”之路
    【C语言进阶】文件操作(一)
    pandas使用str函数和contains函数删除dataframe中单个指定字符串数据列包含特定字符串列表中的其中任何一个字符串的数据行
    【前端JS】ES6的几种新特性
    bash命令——linux command
  • 原文地址:https://blog.csdn.net/qq_38525381/article/details/126884195
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号