微信小程序多列表渲染数据开关互不影响

简介: 微信小程序多列表渲染数据开关互不影响
<!--pages/list/list.wxml-->
<wxs src="../../utils/filter.wxs" module="filter" />
<view class="list">
    <view wx:for="{{list}}" wx:key="{{index}}" class="ban" data-main='{{index}}'>
        <view class="time">{{filter.replaceStar(index)}}</view>
        <view wx:for="{{item}}" wx:key="*this"  class="cen ovf"  data-id='{{item.id}}'  data-index='{{index}}'  >
            <navigator url="../details/details?id={{item.id}}" open-type="navigate" class="ovf  item_1">
               <view>
                       <view class="name">{{item.ymname}}</view>
                       <view class="msg">{{item.ymms}}</view>
               </view>
            </navigator>
            <view class="check ovf">
                    <view   id="jl" bindtap='cancle' wx:if="{{item.seleced==1}}"  data-fid='{{item.fid}}'  data-id='{{item.id}}'  data-index='{{index}}'>已记录</view>
                    <picker mode="date" data-id='{{item.id}}'  data-index='{{index}}' data-fid='{{item.fid}}' bindchange="bindDateChange" bindcancel="bindcancel" class="item_2" name="picker" wx:if="{{item.seleced!=1}}">
                      <view id="jl" bindchange="checkboxChange" value='{{date}}'>记录</view>
                    </picker>
                    <view class="zi" wx:if="{{item.seleced==1}}">{{item.time}}</view>
            </view>
        </view>
    </view>
</view>
<view class="fix" bindtap='wait'>
    <text>查看待\n打疫苗</text>
</view>


// pages/list/list.js
const app = getApp()
var time =''
Page({
  data: {
    id:0,
    list: [],
    date:'',
    tr:'',
    s:''
  },
  //事件处理函数
  // bindcancel:function (e) {
  //   var that = this
  //   console.log(e.target.dataset.id)
  //   that.setData({
  //     tr: 1,
  //   })
  // },
  bindDateChange:function (e) {
    console.log('picker发送选择改变,携带值为', e.detail.value)
    time = e.detail.value
    var that = this
    var arr = that.data.list
    var index = e.target.dataset.index
    var index1 = e.target.dataset.fid
    arr[index1][index].seleced = 1
    arr[index1][index].time = e.detail.value
    that.setData({
      id: e.target.dataset.id,
      date: time,
      list: arr
    })
  },
  cancle:function (e) {
    var that = this
    var arr = that.data.list
    var index = e.target.dataset.index
    var index1 = e.target.dataset.fid
    arr[index1][index].seleced = ''
    that.setData({
      id: e.target.dataset.id,
      list: arr
    })
  },
  wait:function () {
    wx.navigateTo({
      url: '../wait/wait'
    })
  },
  lis: function () {
      wx.navigateTo({
        url: '../archives/archives'
      })
    },
  onLoad: function () {
    var that = this
    wx.request({
      url: 'https://m.renyiwenzhen.com/xcx_ajax.php?action=yimiaolist', //仅为示例,并非真实的接口地址
      method: 'post',
      header: {
        'content-type': 'application/json' // 默认值
      },
      success(res) {
        console.log(res.data)
        that.setData({
          list: res.data
        })
      }
    })
  }
})


总结: 这里使用了双层循环,需要注意的是使用wx:key='*this'循环本身 使用wx:if="{{item.seleced==1}}"标记点击效果,给数据自定义属性


arr[index1][index].seleced = 1
相关文章
|
4月前
|
存储 安全 小程序
在微信小程序中使用 Vant 时如何确保数据的安全?
在微信小程序中使用 Vant 时如何确保数据的安全?
58 1
|
3月前
|
小程序 JavaScript 开发工具
|
3月前
|
缓存 小程序 UED
如何利用小程序的生命周期函数实现数据的加载和更新?
如何利用小程序的生命周期函数实现数据的加载和更新?
117 4
|
3月前
|
移动开发 小程序 数据可视化
微信小程序可视化开发工具之动态数据
微信小程序可视化开发工具之动态数据
58 3
|
4月前
|
JSON 小程序 前端开发
towxml的使用,在微信小程序中快速将markdown格式渲染为wxml文本
本文介绍了在微信小程序中使用`towxml`库将Markdown格式文本渲染为WXML的方法。文章提供了`towxml`的概述、安装步骤、以及如何在小程序中配置和使用`towxml`进行Markdown解析的详细说明和代码示例。
|
4月前
|
小程序 开发者
微信小程序之网络数据请求 wx:request的简单使用
这篇文章介绍了微信小程序中如何使用wx.request进行网络数据请求,包括请求的配置、请求的格式以及如何在开发阶段关闭请求的合法检验。
微信小程序之网络数据请求 wx:request的简单使用
|
3月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
868 7
|
3月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
867 1
|
3月前
|
小程序 前端开发 测试技术
微信小程序的开发完整流程是什么?
微信小程序的开发完整流程是什么?
213 7
ly~
|
4月前
|
存储 供应链 小程序
除了微信小程序,PHP 还可以用于开发哪些类型的小程序?
除了微信小程序,PHP 还可用于开发多种类型的小程序,包括支付宝小程序、百度智能小程序、抖音小程序、企业内部小程序及行业特定小程序。在电商、生活服务、资讯、工具、娱乐、营销等领域,PHP 能有效管理商品信息、订单处理、支付接口、内容抓取、复杂计算、游戏数据、活动规则等多种业务。同时,在企业内部,PHP 可提升工作效率,实现审批流程、文件共享、生产计划等功能;在医疗和教育等行业,PHP 能管理患者信息、在线问诊、课程资源、成绩查询等重要数据。
ly~
99 6