一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務(wù)器之家 - 編程語言 - JavaScript - js教程 - 小程序?qū)崿F(xiàn)自定義多層級單選和多選

小程序?qū)崿F(xiàn)自定義多層級單選和多選

2022-03-07 16:01大灰狼吃小白兔 js教程

這篇文章主要為大家詳細(xì)介紹了小程序?qū)崿F(xiàn)自定義多層級單選和多選,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了小程序?qū)崿F(xiàn)自定義多層級單選和多選的具體代碼,供大家參考,具體內(nèi)容如下

效果:

ps:這兒是用自定義的下拉框,我把它封裝成了一個組件

小程序?qū)崿F(xiàn)自定義多層級單選和多選

wxml

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<view class="select-box">
    <view class="select-title">
        <view class="cell-border">
            <van-field value="{{ layout }}" data-key="layout" placeholder="請輸入" required icon="arrow" label="戶型" bind:tap="onChange" />
        </view>
    </view>
    <view class="select-list" wx:if="{{show}}">
        <view class="option" wx:for="{{layouts}}" wx:key="index">
            <view class="{{curItem.checked ? 'option-item-active' : 'option-item'}}"
                wx:for="{{item.column}}" wx:key="index"
                wx:for-item="curItem"
                data-key="{{curItem.key}}"
                data-colkey="{{item.colKey}}"
                data-name="{{curItem.name}}"
                bind:tap="getOptionItem">
                {{curItem.name}}
            </view>
        </view>
    </view>
</view>

wxss

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
.select-box{
    width: 100%;
    padding: 20rpx;
    box-sizing: border-box;
}
 
.cell-border {
    border-radius: 6rpx;
    border: 1px solid #999;
    margin-bottom: 10rpx;
}
.select-list{
    display: flex;
    flex-direction: row;
    justify-content: space-around;
    width: 100%;
    height: 360rpx;
    padding: 20rpx;
    box-sizing: border-box;
    background-color: #fff;
    border: 1px solid #eee;
}
.select-list .option{
    display: flex;
    flex-direction: column;
    font-size: 24rpx;
}
.option-item{
    width: 80rpx;
    height: 100rpx;
    background-color: #eee;
    text-align: center;
    margin-top: 5px;
    padding: 2px;
 
}
 
.option-item-active{
    width: 80rpx;
    height: 100rpx;
    background-color: #FF6600;
    text-align: center;
    margin-top: 5px;
    padding: 2px;
    color:#fff;
}
json
{
    "component": true,
    "usingComponents": {
      "van-field": "../../vant/field/index",
    }
  }

js

ps:data是組件本身的數(shù)據(jù),layouts是數(shù)據(jù)源

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
Component({
    properties:{
        
    },
    data:{
        show:false,
        curKey:-1,
        colKey:-1,
        layouts:[
            {
                colKey:0,
                column:[
                    {name:"1室",key:0,},
                    {name:"2室",key:1,},
                    {name:"3室",key:2,},
                    {name:"4室",key:3,},
                    {name:"5室",key:4,},
                    {name:"6室",key:5,} ]
            },
            {
                colKey:1,
                column:[
                    {name:"1廳",key:0,},
                    {name:"2廳",key:1,},
                    {name:"3廳",key:2,},
                    {name:"4廳",key:3,},
                    {name:"5廳",key:4,},
                    {name:"6廳",key:5,} ]
            },
            {
                colKey:2,
                column:[
                {name:"1廚",key:0,},
                {name:"2廚",key:1,},
                {name:"3廚",key:2,},
                {name:"4廚",key:3,},
                {name:"5廚",key:4,},
                {name:"6廚",key:5,}]
            },
            {
                colKey:3,
                column:[
                {name:"1衛(wèi)",key:0,},
                {name:"2衛(wèi)",key:1,},
                {name:"3衛(wèi)",key:2,},
                {name:"4衛(wèi)",key:3,},
                {name:"5衛(wèi)",key:4,},
                {name:"6衛(wèi)",key:5,}
                ]
            },
            {
                colKey:4,
                column:[
                    {name:"1陽臺",key:0,},
                    {name:"2陽臺",key:1,},
                    {name:"3陽臺",key:2,},
                    {name:"4陽臺",key:3,},
                    {name:"5陽臺",key:4,},
                    {name:"6陽臺",key:5,}
                    ]
            }
        ]
    },
    methods:{
        onChange(){
            const {show} = this.data;
            this.setData({
                show:!show
            })
        },
        getOptionItem(event){
            console.log("event",event)
            const key = event.currentTarget.dataset.key;
            const cK = event.currentTarget.dataset.colkey;
            const {curKey,colKey,layouts} = this.data;
            this.setData({
                curKey:key,
                colKey:cK
            })
            //用checked字段判斷,允許每列之間單選,多行之間多選
            layouts[cK].column.map(cur => {
                   return cur.checked = false;
            })
            layouts[cK].column[key].checked = true;
            this.setData({layouts})
        }
    }
})

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://blog.csdn.net/weixin_44268473/article/details/103612075

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: videosxxxx老女人 | 国产精品密播放国产免费看 | 国产无限免费观看黄网站 | 情趣内衣在线观看 | 亚洲第一综合网站 | 青青青在线视频 | 玩高中女同桌肉色短丝袜脚文 | 四虎在线免费播放 | 精品女同同性视频很黄很色 | 久青草国产97香蕉在线视频 | 国产一区二区免费在线 | 99ri在线视频网 | 国产一区二区在线观看美女 | 国产精品久久久久影视不卡 | 国产夜趣福利第一视频 | 手机在线观看精品国产片 | 欧美一卡2卡3卡无卡 | 91九色在线视频 | 好男人好资源在线观看 | 国产成人亚洲精品一区二区在线看 | 四虎影视永久在线观看 | 俄罗斯三级完整版在线观看 | 精品国产线拍大陆久久尤物 | yellow高清免费观看日本 | 成人精品视频 成人影院 | 无码人妻丰满熟妇啪啪网不卡 | 四虎国产成人免费观看 | 色中色官网 | 99视频精品国在线视频艾草 | 为什么丈夫插我我却喜欢被打着插 | 女人张开腿让男人做爽爽 | 久久精品无码人妻无码AV蜜臀 | 男人猛戳女人下部30分钟 | 500第一精品 | 青草国内精品视频在线观看 | 人阁色第四影院在线观看 | 亚洲国产精品无码中文字满 | yjsp妖精视频在线观看免费 | 果冻传媒在线视频播放观看 | 欧美日韩精品一区二区三区视频 | videos变态极端 |