微信小程序开发之改变data中数组或对象的某一属性值


Posted in Javascript onJuly 05, 2018

前言:在小程序的开发中,我们在view中便利data中数组或对象时,很多情况下需要在js中动态改变数组或者对象中某一香的属性值。

效果图:

微信小程序开发之改变data中数组或对象的某一属性值

我给大家总结了案例如下:

wxml如下:

<scroll-view class='hd-cont' scroll-x="true" style='width: 100%'>
 <view wx:for="{{sDate}}" wx:key="{{index}}" class='date-cont'>
  <view>{{item.week}}</view>
  <view bindtap='select' data-index="{{index}}" class=' curl {{item.selected}}'>{{item.date}}</view>
 </view>
</scroll-view> 

wxss如下:

.hd-cont {
 height: 126rpx;
 white-space: nowrap;
 padding-left: 20rpx;
 color: #fff;
 font-size: 28rpx;
 box-sizing: border-box;
}
.date-cont {
 width: 40rpx;
 margin-right: 70rpx;
 height: 100%;
 display: inline-block;
 padding-top: 10rpx;
 box-sizing: border-box;
 text-align: center;
}
.curl {
 width: 40rpx;
 height: 40rpx;
 border-radius: 50%;
 line-height: 40rpx;
}
.date-cont view:first-child {
 margin-bottom: 20rpx;
}
.focus {
 display: inline-block;
 width: 40rpx;
 height: 40rpx;
  font-family: Monaco;">#fff;
 color: #16cc80;
 border-radius: 50%;
 line-height: 40rpx;
}

wxjs如下:

实现思路:点击某一个日期时,获取当前点击的下表,点击事件bindtap可以获取到所点击的元素的自定义属性,也就是所点击的元素的在data中数组的下标,点击触发,清空所有对象中selected的值,然后将所点击的下标的selected值变为focus就可实现点击某一元素动态改变数组中的某一属性值。

Page({
data: {
 sDate: [
  { "week": "日", "date": "01" ,"selected": "focus" },
  { "week": "一", "date": "02", "selected": " " },
  { "week": "二", "date": "03", "selected": " " },
  { "week": "三", "date": "04", "selected": " " },
  { "week": "四", "date": "05", "selected": " " },
  { "week": "五", "date": "06", "selected": " " },
  { "week": "六", "date": "07", "selected": " " },
  { "week": "日", "date": "08", "selected": " " },
  { "week": "一", "date": "09", "selected": " " },
  { "week": "二", "date": "10", "selected": " " },
  { "week": "三", "date": "11", "selected": " " },
  { "week": "四", "date": "12", "selected": " " },
  { "week": "五", "date": "13", "selected": " " },
  { "week": "六", "date": "14", "selected": " " },
 ]
},
select: function (e) {
 var oIndex = e.currentTarget.dataset.index;
 var array = this.data.sDate;
 array.forEach( (item,index,arr) => {
  var sItem = "sDate["+ index + "].selected";
  this.setData({
   [sItem]: " "
  })
  console.log([sItem]);
  if(index == oIndex) {
   var oSelected = "sDate[" + index + "].selected"//这里需要将设置的属性用字符串进行拼接
   this.setData({
   [oSelected]: "focus"
   })
  }
 })
},
})

 总结

以上所述是小编给大家介绍的微信小程序开发之改变data中数组或对象的某一属性值,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
js opener的使用详解
Jan 11 Javascript
jQuery中:checkbox选择器用法实例
Jan 03 Javascript
使用node+vue.js实现SPA应用
Jan 28 Javascript
jQuery实现简易的输入框字数计数功能示例
Jan 16 Javascript
Node.js的特点详解
Feb 03 Javascript
js获取浏览器的各种属性
Apr 27 Javascript
详解ElementUI之表单验证、数据绑定、路由跳转
Jun 21 Javascript
关于vue-resource报错450的解决方案
Jul 24 Javascript
微信小程序App生命周期详解
Jan 31 Javascript
VueJs组件之父子通讯的方式
May 06 Javascript
vue 使某个组件不被 keep-alive 缓存的方法
Sep 21 Javascript
十分钟教你上手ES2020新特性
Feb 12 Javascript
JavaScript实现京东购物放大镜和选项卡效果的方法分析
Jul 05 #Javascript
微信小程序实现左右联动的实战记录
Jul 05 #Javascript
vue实现自定义多选与单选的答题功能
Jul 05 #Javascript
JavaScript实现图片懒加载的方法分析
Jul 05 #Javascript
JavaScript实现浅拷贝与深拷贝的方法分析
Jul 05 #Javascript
手把手教你用Node.js爬虫爬取网站数据的方法
Jul 05 #Javascript
vue使用ElementUI时导航栏默认展开功能的实现
Jul 04 #Javascript
You might like
php创建多级目录代码
2008/06/05 PHP
使用PHP提取视频网站页面中的FLASH地址的代码
2010/04/17 PHP
php下连接mssql2005的代码
2011/01/17 PHP
解析在PHP中使用mysqli扩展库对mysql的操作
2013/07/03 PHP
php实现使用正则将文本中的网址转换成链接标签
2014/12/03 PHP
Laravel中log无法写入问题的解决
2017/06/17 PHP
PHP中PDO事务处理操作示例
2018/05/02 PHP
IE6下出现JavaScript未结束的字符串常量错误的解决方法
2010/11/21 Javascript
jquery 插件学习(四)
2012/08/06 Javascript
使用jquery解析XML的方法
2014/09/05 Javascript
js 操作符汇总
2014/11/08 Javascript
浅谈JSON和JSONP区别及jQuery的ajax jsonp的使用
2014/11/23 Javascript
JS中字符串trim()使用示例
2015/05/26 Javascript
js实现文字列表无缝滚动效果
2017/06/23 Javascript
vue-cli构建项目使用 less的方法
2017/10/04 Javascript
深入Vue-Router路由嵌套理解
2018/08/13 Javascript
在Python中使用pngquant压缩png图片的教程
2015/04/09 Python
使用70行Python代码实现一个递归下降解析器的教程
2015/04/17 Python
Python安装第三方库及常见问题处理方法汇总
2016/09/13 Python
Python新手入门最容易犯的错误总结
2017/04/24 Python
python实现kNN算法
2017/12/20 Python
利用python将pdf输出为txt的实例讲解
2018/04/23 Python
dpn网络的pytorch实现方式
2020/01/14 Python
通过Turtle库在Python中绘制一个鼠年福鼠
2020/02/03 Python
jupyter notebook 添加kernel permission denied的操作
2020/04/21 Python
CSS3 圆角效果
2009/07/15 HTML / CSS
CSS3 Notes: -webkit-box-reflect实现倒影的实例
2016/12/08 HTML / CSS
利用Canvas模仿百度贴吧客户端loading小球的方法示例
2017/08/13 HTML / CSS
外贸业务员岗位职责
2013/11/24 职场文书
元旦红领巾广播稿
2014/02/19 职场文书
公安机关纪律作风整顿个人剖析材料材料
2014/10/10 职场文书
公司感谢信范文
2015/01/22 职场文书
农业项目合作意向书
2015/05/08 职场文书
科技活动总结范文
2015/05/11 职场文书
董存瑞观后感
2015/06/11 职场文书
mysql sock文件存储了什么信息
2022/07/15 MySQL