Vue性能优化(2.x)

2021-03-22  本文已影响0人  一个记事本

1、v-if 和 v-show 区分使用场景

所以,v-if 适用于在运行时很少改变条件,不需要频繁切换条件的场景;v-show 则适用于需要非常频繁切换条件的场景。

······························································································································································

2、computed 和 watch 区分使用场景

运用场景:
  • 当我们需要进行数值计算,并且依赖于其它数据时,应该使用 computed,因为可以利用 computed 的缓存特性,避免每次获取值时,都要重新计算;
  • 当我们需要在数据变化时执行异步或开销较大的操作时,应该使用 watch,使用 watch 选项允许我们执行异步操作 ( 访问一个 API ),限制我们执行该操作的频率,并在我们得到最终结果前,设置中间状态。这些都是计算属性无法做到的。

······························································································································································

3、v-for 遍历必须为 item 添加 key,且避免同时使用 v-if

在列表数据进行遍历渲染时,需要为每一项 item 设置唯一 key 值,方便 Vue.js 内部机制精准找到该条列表数据。当 state 更新时,新的状态值和旧的状态值对比,较快地定位到 diff

v-for 比 v-if 优先级高,如果每一次都需要遍历整个数组,将会影响速度,尤其是当之需要渲染很小一部分的时候,必要情况下应该替换成 computed 属性。

推荐:
<ul>
  <li
    v-for="user in activeUsers"
    :key="user.id">
    {{ user.name }}
  </li>
</ul>
computed: {
  activeUsers: function () {
    return this.users.filter(function (user) {
 return user.isActive
    })
  }
}
不推荐:
<ul>
  <li
    v-for="user in users"
    v-if="user.isActive"
    :key="user.id">
    {{ user.name }}
  </li>
</ul>

······························································································································································

4、长列表性能优化

export default {
  data: () => ({
    users: {}
  }),
  async created() {
    const users = await axios.get("/api/users");
    this.users = Object.freeze(users);
  }
};

······························································································································································

5、事件的销毁

created() {
  addEventListener('click', this.click, false)
},
beforeDestroy() {
  removeEventListener('click', this.click, false)  // 对添加的EventListener事件进行销毁
}

······························································································································································

6、图片资源懒加载

//(1)安装插件
npm install vue-lazyload --save-dev
//(2)在入口文件 man.js 中引入并使用
import VueLazyload from 'vue-lazyload'
//(3)然后再 vue 中直接使用
Vue.use(VueLazyload)
// 或者添加自定义选项
Vue.use(VueLazyload, {
preLoad: 1.3,
error: 'dist/error.png',
loading: 'dist/loading.gif',
attempt: 1
})
//(4)在 vue 文件中将 img 标签的 src 属性直接改为 v-lazy ,从而将图片显示方式更改为懒加载显示:
<img v-lazy="/static/img/1.png">

······························································································································································

7、路由懒加载

//路由懒加载:
const Foo = () => import('./Foo.vue')
const router = new VueRouter({
  routes: [
    { path: '/foo', component: Foo }
  ]
})

······························································································································································

8、第三方UI库的按需引入

9、优化无限列表性能

10、代码优化(组件封装)

11、合理使用keep-alive缓存

12、尽量减少data中的数据

上一篇 下一篇

猜你喜欢

热点阅读