小程序改變radio大小,微信小程序修改radio大小
小程序自帶的radio似乎是不能調整大小的,在項目中使用時很不方便,時常會影響整個界面的效果。為了解決這個問題,使用text標簽結合icon標簽實現(xiàn)了radio效果。
接下來看看如何實現(xiàn)的吧。
思路:
左邊一個< text>右邊一個< icon>來實現(xiàn)radio效果。
以列表方式排列所有地區(qū)area,給地區(qū)設置isSelect屬性,如果isSelect=true則顯示的icon 的type為success否則icon的type顯示circle。
當text被點擊時,根據(jù)area的id來確定被點擊的text,被點擊的text對應的area的isSelect屬性設置為true否則設置為false。
先附上wxml文件代碼部分:
- <scroll-view hidden="{{hideArea}}" scroll-y="true" style="height: 100px;" bindscrolltoupper="upper" bindscrolltolower="lower" bindscroll="scroll" scroll-into-view="{{toView}}" scroll-top="{{scrollTop}}">
- <view class="radio-group" >
- <label wx:for="{{areas}}" wx:for-item="area">
- <text bindtap="selectAreaOk" data-areaId="{{area.id}}">{{area.name}}</text>
- <icon wx:if="{{area.isSelect}}" type="success" size="10"/>
- <icon wx:else type="circle" size="10"/>
- </label>
- </view>
- </scroll-view>
先設定一個scroll-view,設置選擇框的父容器位置大小其中radio-group的wxss設定了容器內字體大小已經排練方式
- .radio-group{
- font-size: 26rpx;
- display: flex;
- flex-direction: column;
- }
接下來遍歷了areas數(shù)組用來顯示 地區(qū)名稱+icon 其中為地區(qū)名稱 < text>設置了 bindtap、data-areaId 。這里要跟js進行數(shù)據(jù)交互,其中data-areaId為傳遞過去的參數(shù)。
根據(jù)area對象的isSelect屬性來確定顯示的< icon>,其中一個是圓圈,一個是綠色的對勾。示例中icon的大小設置為10,這里可以隨意改變其大小。
接下來是js代碼部分。
- //選擇區(qū)域
- selectAreaOk: function(event){
- var selectAreaId = event.target.dataset.areaid;
- var that = this
- areaId = selectAreaId
- for(var i = 0;i<this.data.areas.length;i++){
- if(this.data.areas[i].id==selectAreaId){
- this.data.areas[i].isSelect=true
- }else{
- this.data.areas[i].isSelect=false
- }
- }
- this.setData({
- areas:this.data.areas,
- skus:[],
- hideArea:true
- })
- getSkus(that,selectAreaId)
- }
在js代碼里面接收text的點擊事件并接收到傳遞過來的參數(shù),遍歷areas數(shù)組,將選中的area的isSelect屬性設置為true,其余設置為false,再刷新wxml的areas部分。
ok就這么簡單。
第二部分:如何開通一個小商店