vue数据

1.数据绑定:

Vue中有2种数据绑定的方式


1.单向绑定v-bind数据只能从 data 流向页面
2.双向绑定v-model数据不仅能从 data 流向页面,还可以从页面流向 data


备注:


1.双向绑定一般都应用在表单类元素上,如 <input><select><textarea>等
2.v-model:value可以简写为v-model,因为v-model默认收集的就是value值

<div id="root">
      <!-- 普通写法 -->
      <!-- 单向数据绑定:<input type="text" v-bind:value="name"><br/> -->
			<!-- 双向数据绑定:<input type="text" v-model:value="name"><br/> -->

      <!-- 简写 -->
      单向数据绑定:<input type="text" :value="name"><br/>
      双向数据绑定:<input type="text" v-model="name"><br/>

      <!-- 如下代码是错误的,因为 v-model 只能应用在表单类元素(输入类元素)上 -->
      <!-- <h2 v-model:x="name">你好啊</h2> -->
    </div>

2.MVVM模型 数据代理:

1.MVVM模型:


M:模型 Model,data中的数据
V:视图 View,模板代码
VM:视图模型 ViewModel,Vue实例


观察发现:


1.data中所有的属性,最后都出现在了vm身上
2.vm身上所有的属性 及Vue原型身上所有的属性,在 Vue模板中都可以直接使用 

 <div id="root">
        <h2>名称:{{ name }}</h2>
        <h2>战队:{{ rank }}</h2>
        <h2>测试:{{ $options }}</h2>
    </div>

    <script>
        Vue.config.productionTip = false
        new Vue({
            el: '#root',
            data: { 
                name: 'uzi',
                rank: 'RNG'
            }
        })
    </script>

2.Vue 中的数据代理:

数据代理:通过一个对象代理对另一个对象中属性的操作

Object.defineproperty方法:

let number = 18
let person = {
  name: '张三',
  sex: '男',
}

Object.defineProperty(person, 'age', {
  // value:18,
  // enumerable:true,		// 控制属性是否可以枚举,默认值是false
  // writable:true,			// 控制属性是否可以被修改,默认值是false
  // configurable:true	// 控制属性是否可以被删除,默认值是false

  // 当有人读取person的age属性时,get函数(getter)就会被调用,且返回值就是age的值
  get() {
    console.log('有人读取age属性了')
    return number
  },

  // 当有人修改person的age属性时,set函数(setter)就会被调用,且会收到修改的具体值
  set(value) {
    console.log('有人修改了age属性,且值是', value)
    number = value
  }

})
// console.log(Object.keys(person))
console.log(person)

1.Vue中的数据代理通过vm对象来代理data对象中属性的操作(读/写)
2.Vue中数据代理的好处:更加方便的操作data中的数据
3.基本原理
a.通过object.defineProperty()把data对象中所有属性添加到vm上
b.为每一个添加到vm上的属性,都指定一个 gettersetter
c.在gettersetter内部去操作(读/写)data中对应的属性

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title>Vue中的数据代理</title>
    <!-- 引入Vue -->
    <script type="text/javascript" src="../js/vue.js"></script>
  </head>
  <body>

    <div id="root">
      <h2>学校名称:{{ name }}</h2>
      <h2>学校地址:{{ address }}</h2>
    </div>

    <script type="text/javascript">
      Vue.config.productionTip = false

      const vm = new Vue({
        el: '#root',
        data: {
          name: '江西信息应用职业技术学院',
          address: '南昌'
        }
      })
    </script>

  </body>
</html>

  • 12
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 监听Vue数据是指通过Vue提供的监听方法,可以实时监测到数据的变化并做出相应的操作。在Vue中,我们可以使用watch来监听数据的变化。 通过在Vue实例中使用watch属性,我们可以将要监听的数据以字符串形式传递给watch,并在watch中定义一个函数,当数据发生变化时,该函数就会被触发。 例如,假设我们要监听一个叫做"count"的数据,可以在Vue实例中添加如下代码: ``` watch: { count(newValue, oldValue) { console.log('count的值发生变化啦!新的值为:' + newValue + ',旧的值为:' + oldValue); // 可以在这里执行一些自定义的操作 } } ``` 在上述代码中,我们在watch属性中定义了一个count函数,当count数据发生变化时,该函数会被触发。在函数体中,我们可以获取到变化后的新值和变化前的旧值,并可以在这里执行一些自定义的操作。 监听Vue数据可以帮助我们实时获取数据的变化情况,以便及时做出响应。这对于一些需要实时更新数据的场景非常有用,比如当数据发生变化时,我们需要根据新的数据进行计算、展示等操作。 总之,通过监听Vue数据,我们可以在数据变化时得到通知,并进行相应的处理,从而实现数据的实时更新及操作。 ### 回答2: Vue是一种用于构建用户界面的渐进式JavaScript框架。它通过数据驱动和组件化的方式使得开发者可以简单、高效地构建可复用的UI组件。Vue数据监听机制是其核心特性之一。 Vue通过采用响应式的数据绑定机制来监听数据的变化。当一个数据被绑定到Vue实例中的属性时,Vue会将这个属性转化为getter/setter,并且在需要的时候收集依赖和触发更新。这个机制可以让Vue追踪到每个属性的依赖关系,并在属性发生变化时自动更新有关联的组件。 Vue实现数据监听的方式主要有两种:Object.defineProperty和Proxy。在较低版本的浏览器中,Vue使用Object.defineProperty来实现数据监听。它通过重写对象属性的getter和setter来实现依赖追踪和更新通知。在较新版本的浏览器中,Vue使用Proxy来实现数据监听。Proxy可以劫持整个对象,不需要像Object.defineProperty那样重写getter和setter。 对于Vue来说,数据监听是非常重要的,它可以让开发者编写的代码更具有可维护性和可复用性。当数据发生变化时,Vue会自动检测到这些变化并更新相关的组件,从而实现了数据和视图的双向绑定。这种自动化的数据监听机制可以极大地减少开发者的工作量,提高开发效率。 以一个简单示例来说明数据监听的实现方式。假设有一个Vue实例: ```javascript var vm = new Vue({ data: { message: 'Hello Vue!' } }) ``` 当我们修改`data`中的`message`属性时,例如: ```javascript vm.message = 'Hello World!' ``` Vue会自动检测到`message`属性的变化,并更新对应的组件。在这个示例中,Vue会将`message`属性转化为getter/setter,并在需要的时候触发组件的更新操作,使得界面中显示的内容变为新的值。 综上所述,Vue数据监听机制是通过响应式的数据绑定方式来实现的,它是Vue框架的核心特性之一,能够实现数据和视图的自动更新,提高开发效率和减少工作量。 ### 回答3: Vue 是一种用于构建用户界面的渐进式JavaScript框架。它包含了一系列的工具和库,使开发人员能够轻松地构建复杂的单页应用程序。Vue 提供了一种数据监听的机制,可以实时地追踪和更新数据的变化。 Vue数据监听是通过Vue实例中的数据属性来实现的。当数据发生变化时,Vue会自动检测到变化并更新相应的视图。这种监听机制可以确保视图与数据的同步,使开发者能够更加便捷地操作数据和界面。 Vue提供了多种监听数据变化的方式。最常见的方式是使用`v-model`指令将数据绑定到表单元素上,当表单数据发生变化时,Vue会自动更新与之绑定的数据属性。此外,Vue还提供了`watch`属性,可以监听指定数据的变化并执行相应的回调函数。通过`computed`属性,Vue还可以创建计算属性,实时计算数据依赖关系。 除了上述常用方式外,Vue还提供了更高级的数据监听功能。开发者可以使用`$watch`方法手动监听数据的变化。使用该方法,可以监听具体的属性变化,也可以监听整个数据对象的变化。这种方式可以更加灵活地对数据进行监听和操作。 总而言之,Vue提供了灵活而强大的数据监听功能,使开发者能够方便地追踪和处理数据的变化。这为开发人员提供了更好的开发体验和更快速的应用程序开发。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值