小程序里面没有js那样的id选择器,更改样式只能通过this.setData的方式赋值class的值。
但是在循环的时候就不太好用了,会同时更改掉所有样式:
< view wx:for = "{{item.list}}" > < view bindtap = "showContent" data-id = "{{item.id}}" > < view class = "title" >{{item.title}}</ view > </ view > < view class = "{{item.id == currentId ? 'contentShow' : 'contentHiden'}}" > < text >{{item.content}}</ text > </ view > </ view > |
点击“title”来控制“content”的显示隐藏,我这样写最多只能显示一条内容(点击当前“title”的时候,会将其余的全部隐藏),如果要控制到只改变当前点击部位的样式,有好的解决方案吗?
网友回复:
<view wx: for = "{{item.list}}" wx:key= "{{index}}" > <view bindtap= "showContent" data-id= "{{item.id}}" > <view class= "title" >{{item.title}}</view> </view> <view class= "{{item.hide ? 'contentHiden' : 'contentShow'}}" > <text>{{item.content}}</text> </view> </view> |
Page({ data: { item: { list:[ { title: 'USA' , content: '美国' , id: 0, hide: false }, { title: 'CHN' , content: '中国' , id: 1, hide: true }, { title: 'BRA' , content: '巴西' , id: 2, hide: true }, ] } }, showContent: function (e){ var that = this that.data.item.list[e.currentTarget.dataset.id].hide = !that.data.item.list[e.currentTarget.dataset.id].hide that.setData({ item:that.data.item }) } }) |
我理解的你要的效果,如理解不对,请见谅。
感谢麦琪,是这个效果。
那我调整下接口数据,多封装两个属性好了。
再次感谢指点。(抱拳)
动态setData就可以了,小程序嘛,你要抛弃jquery概念。
嗯嗯,受教了,谢谢。
<view class=
"{{item.hide ? 'contentHiden' : 'contentShow'}}"
>
<text>{{item.content}}</text>
</view>
这段代码在我的ios手机上没有起到“点击后隐藏/显示”的效果,我修改成以下代码才出现“点击后隐藏/显示”的效果,
请教可能的原因。
<view wx:if='{{item.hide}}'>{{item.content}}</view>