【微信小程序开发】 动态修改数组&wxs

给小程序添加新的功能遇到一个问题,需要点击CheckBox来修改某个数组里某一项的值。

因为我自己平时有时候会手机备忘录记一点,电脑便签记一点,所以打算给我的小程序【口袋趣屋】添加一个类似于todo的功能。。

动态修改数组

大概类似这样的一个列表
在这里插入图片描述

右边是一个switch, checkbox类型。

点击勾选之后,首先更新数据库,然后更新页面的data。

数据的结构是这样的:
在这里插入图片描述

done为true 的时候就是选中,done 为false的时候表示没有完成。

      db.collection('user_todo_record').doc(id).update({
        data: {
          done: false
        },
        success: function (res) {
          console.log(res)
          let temp = 'content[' + index + '].done'   // 利用这个来表示,就能实现更改数组里的某一项的数据了
          that.setData({
            [temp]: false,
	  // 直接在这个位置写content[index].done 的话,会提示错误,不能识别
          })
        }
      })

wxs

参考: 官方文档

利用wx:for 渲染数组的时候,我想根据数组里的元素的id是否在另一个数组里来判断单选框是否处于选中状态。

小程序页面的语法是不支持直接indexOf的,所以需要使用wxs。

WXS(WeiXin Script)是小程序的一套脚本语言,结合 WXML,可以构建出页面的结构。WXS 与 JavaScript 是不同的语言,有自己的语法,并不和 JavaScript 一致。

// array.wxs

function defineIndexOf(str, val) {
  return str.indexOf(val);
}
module.exports = {
  indexOf: defineIndexOf
}
<wxs src="array.wxs" module="arrayTool" />

<switch type="checkbox" value="{{item._id}}" checked="{{arrayTool.indexOf(today_info, item._id) > -1?true:''}}" bindchange="todoCom" data-id="{{item._id}}"/>

我的个人博客链接

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值