微信小程序開(kāi)發(fā)之改變data中數(shù)組或?qū)ο蟮哪骋粚傩灾?/h1>
更新時(shí)間:2018年07月05日 10:12:12 作者:狗尾草的博客
本文通過(guò)案例給大家分析了微信小程序開(kāi)發(fā)之改變data中數(shù)組或?qū)ο蟮哪骋粚傩灾?本文通過(guò)實(shí)例代碼相結(jié)合的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
前言:在小程序的開(kāi)發(fā)中,我們?cè)趘iew中便利data中數(shù)組或?qū)ο髸r(shí),很多情況下需要在js中動(dòng)態(tài)改變數(shù)組或者對(duì)象中某一香的屬性值。
效果圖:

![]()
我給大家總結(jié)了案例如下:
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如下:
實(shí)現(xiàn)思路:點(diǎn)擊某一個(gè)日期時(shí),獲取當(dāng)前點(diǎn)擊的下表,點(diǎn)擊事件bindtap可以獲取到所點(diǎn)擊的元素的自定義屬性,也就是所點(diǎn)擊的元素的在data中數(shù)組的下標(biāo),點(diǎn)擊觸發(fā),清空所有對(duì)象中selected的值,然后將所點(diǎn)擊的下標(biāo)的selected值變?yōu)閒ocus就可實(shí)現(xiàn)點(diǎn)擊某一元素動(dòng)態(tài)改變數(shù)組中的某一屬性值。
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"http://這里需要將設(shè)置的屬性用字符串進(jìn)行拼接
this.setData({
[oSelected]: "focus"
})
}
})
},
})
總結(jié)
以上所述是小編給大家介紹的微信小程序開(kāi)發(fā)之改變data中數(shù)組或?qū)ο蟮哪骋粚傩灾?,希望?duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
您可能感興趣的文章:- 微信小程序 兩種為對(duì)象屬性賦值的方式詳解
- 微信小程序?qū)崿F(xiàn)通過(guò)js操作wxml的wxss屬性示例
- 微信小程序button標(biāo)簽open-type屬性原理解析
- 微信小程序wx.navigateTo中events屬性實(shí)現(xiàn)頁(yè)面間通信傳值,數(shù)據(jù)同步
- 微信小程序模板(template)使用詳解
- 微信小程序視圖template模板引用的實(shí)例詳解
- 微信小程序 template模板詳解及實(shí)例
- 微信小程序模板消息推送的兩種實(shí)現(xiàn)方式
- 微信小程序 template模板詳解及實(shí)例代碼
- 微信小程序模板和模塊化用法實(shí)例分析
- 微信小程序?qū)W習(xí)總結(jié)(二)樣式、屬性、模板操作分析
相關(guān)文章
-
在Html中使用Requirejs進(jìn)行模塊化開(kāi)發(fā)實(shí)例詳解
在前端模塊化的時(shí)候,不僅僅是js需要進(jìn)行模塊化管理,html有時(shí)候也需要模塊化管理。這里就介紹下如何通過(guò)requirejs,實(shí)現(xiàn)html代碼的模塊化開(kāi)發(fā) 2016-04-04
-
原生javascript自定義input[type=radio]效果示例
這篇文章主要介紹了原生javascript自定義input[type=radio]效果,結(jié)合實(shí)例形式分析了javascript模擬form表單中radio效果的相關(guān)操作技巧,需要的朋友可以參考下 2019-08-08
-
javascript Array對(duì)象使用小結(jié)
數(shù)組是一段線性分配的內(nèi)存,它通過(guò)整數(shù)去計(jì)算偏移并訪問(wèn)其中的元素。數(shù)組是很快的數(shù)據(jù)結(jié)構(gòu),但不幸的是,Javascript并沒(méi)有像這種數(shù)組一樣的數(shù)據(jù)結(jié)構(gòu)。 2009-12-12
-
JavaScript實(shí)現(xiàn)鼠標(biāo)點(diǎn)擊后層展開(kāi)效果的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)鼠標(biāo)點(diǎn)擊后層展開(kāi)效果的方法,可實(shí)現(xiàn)點(diǎn)擊文字緩慢展開(kāi)層的效果,具有一定參考借鑒價(jià)值,需要的朋友可以參考下 2015-05-05
-
JavaScript箭頭函數(shù)_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了JavaScript箭頭函數(shù)的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下 2017-06-06
-
線路分流自動(dòng)跳轉(zhuǎn)代碼;希望對(duì)大家有用!
線路分流自動(dòng)跳轉(zhuǎn)代碼;希望對(duì)大家有用!... 2006-12-12
-
js控制滾動(dòng)條緩慢滾動(dòng)到頂部實(shí)現(xiàn)代碼
滾動(dòng)條緩慢滾動(dòng)到頂部這樣的效果想必大家在瀏覽網(wǎng)頁(yè)的時(shí)候都有見(jiàn)過(guò)吧,本文使用js實(shí)現(xiàn)下,感興趣的你可不要錯(cuò)過(guò)了哈,希望可以幫助到你 2013-03-03
最新評(píng)論
前言:在小程序的開(kāi)發(fā)中,我們?cè)趘iew中便利data中數(shù)組或?qū)ο髸r(shí),很多情況下需要在js中動(dòng)態(tài)改變數(shù)組或者對(duì)象中某一香的屬性值。
效果圖:
我給大家總結(jié)了案例如下:
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如下:
實(shí)現(xiàn)思路:點(diǎn)擊某一個(gè)日期時(shí),獲取當(dāng)前點(diǎn)擊的下表,點(diǎn)擊事件bindtap可以獲取到所點(diǎn)擊的元素的自定義屬性,也就是所點(diǎn)擊的元素的在data中數(shù)組的下標(biāo),點(diǎn)擊觸發(fā),清空所有對(duì)象中selected的值,然后將所點(diǎn)擊的下標(biāo)的selected值變?yōu)閒ocus就可實(shí)現(xiàn)點(diǎn)擊某一元素動(dòng)態(tài)改變數(shù)組中的某一屬性值。
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"http://這里需要將設(shè)置的屬性用字符串進(jìn)行拼接 this.setData({ [oSelected]: "focus" }) } }) }, })
總結(jié)
以上所述是小編給大家介紹的微信小程序開(kāi)發(fā)之改變data中數(shù)組或?qū)ο蟮哪骋粚傩灾?,希望?duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- 微信小程序 兩種為對(duì)象屬性賦值的方式詳解
- 微信小程序?qū)崿F(xiàn)通過(guò)js操作wxml的wxss屬性示例
- 微信小程序button標(biāo)簽open-type屬性原理解析
- 微信小程序wx.navigateTo中events屬性實(shí)現(xiàn)頁(yè)面間通信傳值,數(shù)據(jù)同步
- 微信小程序模板(template)使用詳解
- 微信小程序視圖template模板引用的實(shí)例詳解
- 微信小程序 template模板詳解及實(shí)例
- 微信小程序模板消息推送的兩種實(shí)現(xiàn)方式
- 微信小程序 template模板詳解及實(shí)例代碼
- 微信小程序模板和模塊化用法實(shí)例分析
- 微信小程序?qū)W習(xí)總結(jié)(二)樣式、屬性、模板操作分析
相關(guān)文章
在Html中使用Requirejs進(jìn)行模塊化開(kāi)發(fā)實(shí)例詳解
在前端模塊化的時(shí)候,不僅僅是js需要進(jìn)行模塊化管理,html有時(shí)候也需要模塊化管理。這里就介紹下如何通過(guò)requirejs,實(shí)現(xiàn)html代碼的模塊化開(kāi)發(fā)2016-04-04原生javascript自定義input[type=radio]效果示例
這篇文章主要介紹了原生javascript自定義input[type=radio]效果,結(jié)合實(shí)例形式分析了javascript模擬form表單中radio效果的相關(guān)操作技巧,需要的朋友可以參考下2019-08-08javascript Array對(duì)象使用小結(jié)
數(shù)組是一段線性分配的內(nèi)存,它通過(guò)整數(shù)去計(jì)算偏移并訪問(wèn)其中的元素。數(shù)組是很快的數(shù)據(jù)結(jié)構(gòu),但不幸的是,Javascript并沒(méi)有像這種數(shù)組一樣的數(shù)據(jù)結(jié)構(gòu)。2009-12-12JavaScript實(shí)現(xiàn)鼠標(biāo)點(diǎn)擊后層展開(kāi)效果的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)鼠標(biāo)點(diǎn)擊后層展開(kāi)效果的方法,可實(shí)現(xiàn)點(diǎn)擊文字緩慢展開(kāi)層的效果,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-05-05JavaScript箭頭函數(shù)_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了JavaScript箭頭函數(shù)的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06線路分流自動(dòng)跳轉(zhuǎn)代碼;希望對(duì)大家有用!
線路分流自動(dòng)跳轉(zhuǎn)代碼;希望對(duì)大家有用!...2006-12-12js控制滾動(dòng)條緩慢滾動(dòng)到頂部實(shí)現(xiàn)代碼
滾動(dòng)條緩慢滾動(dòng)到頂部這樣的效果想必大家在瀏覽網(wǎng)頁(yè)的時(shí)候都有見(jiàn)過(guò)吧,本文使用js實(shí)現(xiàn)下,感興趣的你可不要錯(cuò)過(guò)了哈,希望可以幫助到你2013-03-03