微信小程序 --- 简易双向绑定

目录

简易双向绑定

双向绑定语法

在自定义组件中传递双向绑定

在自定义组件中触发双向绑定更新


简易双向绑定

基础库 2.9.3 开始支持,低版本需做兼容处理

双向绑定语法

在 WXML 中,普通的属性的绑定是单向的。例如:

复制代码
<input value="{{value}}" />

如果使用 this.setData({ value: 'leaf' }) 来更新 valuethis.data.value 和输入框的中显示的值都会被更新为 leaf ;但如果用户修改了输入框里的值,却不会同时改变 this.data.value

如果需要在用户输入的同时改变 this.data.value ,需要借助简易双向绑定机制。此时,可以在对应项目之前加入 model: 前缀:

复制代码
<input model:value="{{value}}" />

这样,如果输入框的值被改变了, this.data.value 也会同时改变。同时, WXML 中所有绑定了 value 的位置也会被一同更新, 数据监听器 也会被正常触发。

在开发者工具中预览效果

用于双向绑定的表达式有如下限制:

  1. 只能是一个单一字段的绑定,如

都是非法的;

  1. 目前,尚不能 data 路径,如

这样的表达式目前暂不支持。

在自定义组件中传递双向绑定

双向绑定同样可以使用在自定义组件上。如下的自定义组件:

复制代码
// custom-component.js
Component({
  properties: {
    myValue: String
  }
})

<!-- custom-component.wxml -->
<input model:value="{{myValue}}" />

这个自定义组件将自身的 myValue 属性双向绑定到了组件内输入框的 value 属性上。这样,如果页面这样使用这个组件:

复制代码
<custom-component model:my-value="{{pageValue}}" />

当输入框的值变更时,自定义组件的 myValue 属性会同时变更,这样,页面的 this.data.pageValue 也会同时变更,页面 WXML 中所有绑定了 pageValue 的位置也会被一同更新。

在自定义组件中触发双向绑定更新

自定义组件还可以自己触发双向绑定更新,做法就是:使用 setData 设置自身的属性。例如:

复制代码
// custom-component.js
Component({
  properties: {
    myValue: String
  },
  methods: {
    update: function() {
      // 更新 myValue
      this.setData({
        myValue: 'leaf'
      })
    }
  }
})

如果页面这样使用这个组件:

复制代码
<custom-component model:my-value="{{pageValue}}" />

当组件使用 setData 更新 myValue 时,页面的 this.data.pageValue 也会同时变更,页面 WXML 中所有绑定了 pageValue 的位置也会被一同更新。

相关推荐
fzil0012 分钟前
让 AI 自己协作 —— 多智能体(Swarm)系统的设计与实现
java·开发语言·人工智能·ubuntu
Mem0rin6 分钟前
[Java/数据结构]二叉树练习题几则
java·开发语言·数据结构
lhbian8 分钟前
PHP vs Java vs Go:编程语言终极对比
java·spring boot·后端·kafka·linq
java修仙传10 分钟前
从手写 Redis 锁到 Redisson:我对分布式锁安全性的理解
java·数据库·redis·分布式
iiiiyu14 分钟前
常用API(Object类 & Objects类)
java·开发语言
小碗羊肉15 分钟前
【从零开始学Java | 第三十六篇】字符流
java·开发语言
海寻山29 分钟前
Java枚举(Enum):基础语法+高级用法+实战场景+面试避坑
java·开发语言·面试
weixin_4713830331 分钟前
React Flow + Zustand 搭建工作流编排工作台
前端·react.js·前端框架
鱼鳞_32 分钟前
Java学习笔记_Day31(IO流)
java·笔记·学习
kilito_0132 分钟前
react疑难讲解
前端·react.js·前端框架