我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

前言

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

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

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

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

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


<template>
  <div>{{msg}}</div>
</template>

<script>
export default {
  data() {
    msg: "" 
  }
};
</script>

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

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

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

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


<script>
const age = 'bar'
export default {
  methods: {
    getAge() {
      return age
    },
    concatName() {
      let name = 'nordon'
      reutrn `name:${name}, age: ${age} `
    }
  },
};
</script>

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


<template>
  <div v-for="item in arr">{{item.name}}</div>
</template>

<script>
const arr = Object.freeze([{
  name: 'nordon',
  age: 18
}])
export default {
  data() {
    return {
      arr
    }
  }
};
</script>

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

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


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

总结

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

vue LogicFlow自定义边实现示例详解

这篇文章主要为大家介绍了vue LogicFlow自定义边示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-01-11

详解Vue如何自定义hooks(组合式)函数

这篇文章主要为大家详细介绍了在Vue中如何实现自定义hooks(组合式)函数,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
2023-03-13

Android如何自定义升级对话框示例详解

前言本文主要给大家介绍了关于Android自定义升级对话框的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。实现的效果如下所示其实这也只是一个DialogFragment 而已,重点只是在于界面的设计想要使用做出这
2023-05-30

VUEv-bind数据绑定的示例详解

这篇文章主要介绍了VUEv-bind数据绑定,简单点来说就是对HTML中的元素,我们可以使用v-bind来进行绑定和动态的数据输出,本文结合示例代码给大家介绍的非常详细,需要的朋友可以参考下
2023-05-19

vue中使用window.open()参数示例详解

这篇文章主要介绍了vue中使用window.open()参数详解,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-17

Vue 事件处理函数的绑定示例详解

这篇文章主要为大家介绍了Vue 事件处理函数的绑定示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-02-23

Oracle数据库中TRUNC()函数示例详解

目录前言一、TRUNC函数的语法二、主要用途三、测试用例1、测试日期截取2、测试数值截取需要注意以下几点:总结前言在oracle中,TRUNC函数用于截取或截断日期、时间或数值表达式的部分。它返回一个日期、时间或数值的截断版本,根据提供的
Oracle数据库中TRUNC()函数示例详解
2024-10-22

Vue自定义指令实现点击右键弹出菜单示例详解

这篇文章主要为大家介绍了Vue自定义指令实现点击右键弹出菜单示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-01-11

编程热搜

目录