vue的性能优化

一、Object.freeze()可以减少Observer

冻结无需改变的数据,避免框架继续遍历其属性,完成响应式(双向数据绑定)

<script>
export default {
    data() {
        return {
            list: []
        }
    },
    created() {
        let data = new Array(100000).fill(null).map((it, i) => i);
        // this.list = data;  // 优化前
        // 冻结无需改变的数据,避免框架继续遍历其属性,完成响应式(双向数据绑定)
        this.list = Object.freeze(data);  // 优化后
    }
}
</script>

效果:

 二、组件<style>,加scoped问题

有些样式可以全局的就全局,实在不行就scoped局部, 样式是从右往左查找的  ,,,不说了 略·····   能全局就全局    不能就算了

三、减少不必要的组件根标签

原因:vue2中每一个组件都需要一个跟标签包裹住组件的内容,当我们有一百个组件时,就会有一百个多余的标签

解决: 引入一个组件vue-fragment包裹,充当包裹组件内容的根组件,当我们审查元素的时候看到它是一个注释,这个组件的目的是达到一个欺骗编译器的作用

1、安装

npm i -s vue-fragment

2、main.js全局引入

import Vue from 'vue'
import fragment from 'vue-fragment'
Vue.use(Fragment.Plugin)

3、组件中使用

<template>
    <!--代码片段: 虚拟元素 - 框架作为代码片段来蒙骗框架,在页面成为注释-->
    <fragment>
        <ima src="">
        <div><div>
    <fragment>
</template>

4、页面成为注释

 缺点:

 1、对于路由的根组件,切换时,由于本身是代码片段,所以无法使用parent.removeChild、insertBefore等方法,

2、可以使用在子组件内部(路由根组件有问题)

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值