微信小程序 双向绑定

注意事项

基础库 2.9.3 开始支持双向绑定

普通属性绑定示例

页面 WXML

<!-- 在页面中,提供修改数据的方法 -->
<view bind:tap="onTap">{{ msg }}</view>
<!-- 普通属性绑定 -->
<input type="text" value="{{ msg }}" />

页面 JS

Page({
  data: {
    msg: 'Hello world!'
  },

  onTap() {
    this.setData({ msg: this.data.msg + '!' })
  }
})
  • 当点击 view 时,msg 发生变化,input 的内容会同时改变
  • 当在 input 中进行输入,msg 并不会同时改变

使用 model: 前缀进行双向绑定

页面 WXML

<!-- 在页面中,提供修改数据的方法 -->
<view bind:tap="onTap">{{ msg }}</view>
<!-- 双向绑定 -->
<input type="text" model:value="{{ msg }}" />

页面 JS

Page({
  data: {
    msg: 'Hello world!'
  }
})
  • 此时当在 input 中进行输入,msg 会同时改变,并且 view 的显示内容也会更新

自定义组件和双向绑定

页面包含一个自定义组件 component, 自定义组件包含一个内置组件 input

页面 WXML

<!-- 在页面中,提供修改数据的方法 -->
<view bind:tap="onTap">{{ msg }}</view>
<!-- component 是自定义组件,页面和自定义组件进行双向绑定 -->
<component model:component-value="{{ msg }}" />

页面 JS

Page({
  data: {
    msg: 'Hello world!'
  },

  onTap() {
    this.setData({ msg: this.data.msg + '!' })
  }
})

自定义组件 WXML

<!-- 自定义组件和 input 进行双向绑定 -->
<input type="text" model:value="{{ componentValue }}" />
<!-- 在自定义组件中,提供修改数据的方法 -->
<button bind:tap="modifyValue">修改 componentValue</button>

自定义组件 JS

Component({
  properties: {
    componentValue: String
  },

  observers: {
    componentValue: (newVal) => {
      // 监听 componentValue 的变化
      console.log(`componentValue 发生变化:${newVal}`)
    }
  },

  methods: {
    modifyValue() {
      // 在自定义组件中,使用 setData 修改数据,可以触发双向绑定更新
      this.setData({ componentValue: this.data.componentValue + '!' })
    }
  }
})
  • 页面自定义组件进行双向绑定
  • 自定义组件内置组件(input)进行双向绑定
  • 此时,当在页面修改 msg, 在自定义组件修改 componentValue, 在 input 中修改 value (在 input 中进行输入),其他位置的数据也会跟着发生变化
  • 只要数据发生变化,自定义组件的 observers 就能监听到
  • 15
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值