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

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

效果图:

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

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"
            })
        }
    })
},
})

这里狗尾草也就给大家总结完了,希望对大家有所帮助,有问题记得及时反馈哦,狗尾草和大家一起进步。

原文地址:https://www.cnblogs.com/bgwhite/p/9265849.html

时间: 2024-11-11 06:50:31

小程序开发之改变data中数组或对象的某一属性值的相关文章

微信小程序开发《三》:微信小程序请求不能使用session的原因及解决办法

本人在前面的微信小程序开发<二>中提到要想在服务端保持状态需要在客户端第一次请求服务器的时候给客户端返回一个sessionid,由客户端在本地保存,下次请求的时候在header里面带上这个sessionid,写到cookie字段里.但是最近发现请求时哪怕每次在header里带上sessionid还是不能拿到同一个session,百度后终于发现坑了(也不知道微信为啥要这么做),原来微信对wx.request这个API做了修改,小程序发起的请求并不是直接请求我们的后台服务器,而是先通过微信的服务器

9-简单实例(二)小程序开发中应注意的几个问题

前面,我们比较完整地讲了一个开放"知乎新闻"的实例.为什么说比较完整呢?因为只是那么一篇文章,要完整地讲完,谈何容易.反正有渔老师是没这个能力.下面接着来完善上篇文章,希望读者看完后,能更加深刻地认识微信小程序开发. 1.新添加的目录,有没有添加到app.json的pages里? "pages":[ "pages/index/index", "pages/detail/detail" ], 每添加一个页面,就需要把页面的路径写

小程序开发中有趣的事情

小程序开发做了半年了,断断续续地利用课余时间写了一大部分. 期间遇到了很多坑和技巧,个人感觉十分有趣. 1.textarea 小程序里面的textarea是我遇到的第一个坑. textarea 在小程序里面看起来似乎和HTML里的一样,但是页面一滑动就有问题:欸欸欸??卧槽,卧槽,他怎么不动?:如果页面有弹层,弹层弹出的瞬间,卧槽卧槽?这个怎么在最上面?.textarea在小程序里面是原生层级最高的组件,z-index对他没用,并且在swipe.scroll-view.canve里面会出现奇奇怪

解决微信小程序开发中wxss中不能用本地图片

微信小程序开发中wxss中不能用本地图片,我们可以用将我们的图片传到服务器上,然后直接引用在线地址.但是当我们没有服务器时,我们可以用"图床",这个具体可以百度.这里我们用第二种方法:将图片用base64加密. 1.我们用在线加密对图片进行加密,这个网址百度一大堆,我只贴出一个http://imgbase64.duoshitong.com/ 2.将转换完成后的base64复制到我们要引用的地方. 3.设置样式(辅助代码,只有将这个图片做为background-image时注意设置如下属

微信小程序开发中wx.redirectTo与wx.navigateTo跳转页面未果

学习小程序开发中难免遇到一些小坑,作者在进行登录功能时遇到登录成功后,页面不可实现跳转到个人中心(admin/admin). 首先大致介绍一下本文的逻辑:验证用户信息后,需跳转页面到个人中心(tabBar页面),采用wx.redirectTo与wx.navigateTo两种方法均未实现,且不报错. 主要原因: admin/admin属于tabBar页面,采用上述两方法不会有任何效果,需采用wx.switchTab法进行跳转. 跳转完成页面: 页面跳转方法: 1.wx.navigateTo 保留当

微信小程序开发备忘

前言 从去年一月份微信宣告要做小程序时的圈子里已经有了局部躁动,去年九月内测时,更是全民热捧,似乎张晓龙和他的微信已经准备好再一次改变世界.还好微信比它的粉丝们要理智的多,不做分发,不搞渠道,不发"红利",所以,昨天正式发布时,也并没有想象中的所有人一起迎接新世界到来的景象.OSC上有人发帖问"微信小程序就要发布了,大家激动吗",底下居然都已经有人开喷了.. 但是,话说回来,从技术角度看,微信为我们提供了基于微信本身的新应用场景下的新技术,那么作为一个开发者,对他有

微信小程序开发:学习笔记[2]——WXML模板

微信小程序开发:学习笔记[2]--WXML模板 快速开始 介绍 WXML 全称是 WeiXin Markup Language,是小程序框架设计的一套标签语言,结合小程序的基础组件.事件系统,可以构建出页面的结构. 打开开发工具的编辑器,在根目录下找到 app.json 文件,双击打开,在 "pages/index/index" 上新增一行 "pages/wxml/index" 保存文件.模拟器刷新后,读者可以在编辑器中找到 pages/wxml/index.wxm

微信小程序开发基础(一)「配置」与「逻辑层」

微信小程序作为微信生态重要的一环,在实际生活.工作.商业中的应用越来越广泛.想学习微信小程序开发的朋友也越来越多,本文将在小程序框架的基础上就微信小程序项目开发所必需的基础知识及语法特点进行了详细总结和阐述,包括配置.函数.语法.事件及其处理.数据绑定.模块.样式等.想开发小程序,这些内容是必须掌握的. 全文知识结构预览: 一.程序配置: 1.全局配置:2.页面配置 二.逻辑层: 1.程序注册:App()方法:2.页面注册:Page()方法:3.模块与调用:4.微信原生API 三.视图层(将在单

微信小程序开发心得

微信小程序也已出来有一段时间了,最近写了几款微信小程序项目,今天来说说感受. 首先开发一款微信小程序,最主要的就是针对于公司来运营的,因为,在申请appid(微信小程序ID号)时候,需要填写相关的公司认证信息如,营业执照等 再次就是用一个未曾开通过公众号的QQ号或微信号来注册一个微信小程序号. 最后,下载微信小程序开发工具. 由于这里,我们更多的关注如何去开发一些app,而不是科谱微信小程序,故在此不在过多的解释,详细的说明,可以去官网帮助文档. 首先,我们拿自己的项目在一步一步的说明并开发吧,