vue--3.数据绑定(响应式数据和双向数据绑定)、过滤器(面试)

本文深入探讨了Vue.js中的数据绑定,包括响应式数据和双向数据绑定的实现原理,以及系统指令v-model的使用。响应式数据通过Object.defineProperty实现数据劫持和发布者-订阅者模式,确保UI随数据变化实时更新。双向数据绑定则允许UI与数据容器双向同步,常见于表单元素。此外,文章还介绍了过滤器在数据展示前的应用,用于数据的预处理,并给出了实际示例。
摘要由CSDN通过智能技术生成

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


1.数据绑定(面试)

响应式数据:只能由代码改变UI或者只能由UI改变代码

双向数据绑定:代码改变UI,UI也能改变代码

双向数据绑定的实现: 2种方式

1.自己实现,vue可以自己实现(没必要) 微信开发可以自己实现(只能自己实现) 利用input事件,用户交互的时候,获取用户输入的值,然后把值绑定到data容器中

利用 Object.defineProperty 自己实现双向数据绑定

2.系统指令:v-model

(1) .响应式数据

什么是响应式数据?

==>如果内存中的数据变化了,页面UI也会动态跟着刷新,这种数据就是响应式数据

示例如下:

 

响应式数据设计的设计原理:

        vue2.0采用数据劫持结合发布者-订阅者模式的方式,通过Object.defineProperty()来劫持各个属性的setter,getter,在数据变动时发布消息给订阅者,触发相应监听回调。当把一个普通 Javascript 对象传给 Vue 实例来作为它的 data 选项时,Vue 将遍历它的属性,用 Object.defineProperty 将它们转为 getter/setter。用户看不到 getter/setter,但是在内部它们让 Vue 追踪依赖,在属性被访问和修改时通知变化。

(2) .双向数据绑定

双向数据绑定概念:

         1.如果数据容器中的变量变了也会让页面刷新(dom操作让页面改变),

         2.如果用户操作dom,改变了页面,反之也会让数据容器中的变量的值改变

示例如下:

 

2.过滤器(面试)

filter主要用于数据展示之前的处理

过滤器只能用在v-bind或者插值表达式

过滤器的写法如下:

 

应用示例如下:

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值