首页 >> js开发 >> js微信小程序多列表渲染数据开关互不影响的实现js大全
js微信小程序多列表渲染数据开关互不影响的实现js大全
发布时间: 2021年1月13日 | 浏览:
| 分类:js开发
最近在学习小程序,正好发现一个问题,微信小程序多列表渲染数据开关怎么互不影响,记录一下,分享给大家
{{filter.replaceStar(index)}}
{{item.ymname}}
{{item.ymms}}
已记录
记录
{{item.time}}
查看待\n打疫苗
{{filter.replaceStar(index)}}
{{item.ymname}}
{{item.ymms}}
已记录
记录
{{item.time}}
查看待\n打疫苗
// 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
})
}
})
}
})
// 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}}"标记点击效果,给数据自定义属性wx:key='*this'wx:if="{{item.seleced==1}}"
arr[index1][index].seleced = 1
arr[index1][index].seleced = 1
// 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
})
}
})
}
})
// 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}}"标记点击效果,给数据自定义属性wx:key='*this'wx:if="{{item.seleced==1}}"
arr[index1][index].seleced = 1
arr[index1][index].seleced = 1
相关文章:
- jsVue-CLI 3 scp2自动部署项目至服务器的方法js大全
- js在vue中使用防抖函数组件操作js大全
- jsVue中的this.$options.data()和this.$data用法说明js大全
- jsElement Breadcrumb 面包屑的使用方法js大全
- js解决vue动态路由异步加载import组件,加载不到module的问题js大全
- jsAngular利用HTTP POST下载流文件的步骤记录js大全
- js解决vuex数据页面刷新后初始化操作js大全
- jsvue 页面回退mounted函数不执行的解决方案js大全
- jsvue项目使用$router.go(-1)返回时刷新原来的界面操作js大全
- jsElement Input输入框的使用方法js大全