Vue中如何定义数据示例详解 - 网站

Vue中如何定义数据示例详解

分类:Vue.js 教程 · 发布时间:2023-04-18 11:41 · 阅读:8912

这篇文章主要给大家介绍了关于Vue中如何定义数据的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用vue具有一定的参考学习价值,需要的朋友可以参考下

前言

在开发的过程中,定义变量是一件非常高频且十分基础的事情,如何合理的根据变量的使用场景和作用域范围进行定义变量,是一件很小缺很容易犯错的事情

Vue2已经流行使用了这么多年,多数开发者在开发过程中喜爱在data选项中梭哈定义很多变量,这样做非常不利于代码的阅读性、维护性和性能,想要很好的使用变量,需要结合Vue和JS的特性

在Vue中,按照是否需要双向数据绑定,可以将变量分为两种:

一种是需要被Vue的数据劫持,将data的变化实时响应到view上

只要data只能够的msg变化, template中绑定的msg会实时响应

 

还有一种不需要被Vue数据劫持:

仅在script中生效,在template中没有使用,不需要数据劫持

name仅在concatName函数中生效,那么将其作为局部变量定义即可

age在函数getAge和concatName中都需要使用,作为局部变量使用不合适,那么可以将其作用域提升,方便在多个地方使用

 

仅仅是在template中作为渲染数据使用,自定义之后便不会在后续的操作中对其修改,这种数据如果使用Vue对其数据劫持会浪费一些性能

 

使用Object.freeze将不需要数据劫持的数据进行冻结操作,在Vue中递归遍历数据进行数据劫持的时候便不会对其进行数据劫持,特别对于大量的表格类的数据性能提升会显著一些

可以从Vue源码中看到,为何使用了Object.freeze对数据处理之后,便不会再进行数据劫持

 function defineReactive (obj, key) { // 删除无关代码 只保留了判断条件 const property = Object.getOwnPropertyDescriptor(obj, key) if (property && property.configurable === false) { return } } 

总结

到此这篇关于Vue中如何定义数据的文章就介绍到这了,更多相关Vue定义数据内容请搜索0133技术站以前的文章或继续浏览下面的相关文章希望大家以后多多支持0133技术站!

标签:
vue 定义 数据

相关文章

vue加载视频流,实现直播功能的过程

这篇文章主要介绍了vue加载视频流,实现直播功能的过程,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

Vue2项目升级到Vue3的详细教程

看到好多开源项目都升级了vue3,下面这篇文章主要给大家介绍了关于Vue2项目升级到Vue3的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下

解决v-model双向绑定失效的问题

这篇文章主要介绍了解决v-model双向绑定失效的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

Vue面试必备之防抖和节流的使用

在这篇文章中,大家会了解到如何在 Vue 组件中使用防抖和节流控制 观察者(watchers)以及事件处理程序,文中的示例代码简洁易懂,希望对大家有所帮助

element中async-validator异步请求验证使用

本文主要介绍了element中async-validator异步请求验证使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

返回分类 返回首页