小程序实现自定义多层级单选和多选

 更新时间:2021年04月21日 11:29:36   作者:大灰狼吃小白兔  
这篇文章主要为大家详细介绍了小程序实现自定义多层级单选和多选,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了小程序实现自定义多层级单选和多选的具体代码,供大家参考,具体内容如下

效果:

ps:这儿是用自定义的下拉框,我把它封装成了一个组件

wxml

<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

.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是组件本身的数据,layouts是数据源

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卫",key:0,},
                {name:"2卫",key:1,},
                {name:"3卫",key:2,},
                {name:"4卫",key:3,},
                {name:"5卫",key:4,},
                {name:"6卫",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})
        }
    }
})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • js canvas实现俄罗斯方块

    js canvas实现俄罗斯方块

    这篇文章主要为大家详细介绍了js canvas实现俄罗斯方块,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-10-10
  • webpack多入口打包示例代码

    webpack多入口打包示例代码

    这篇文章主要介绍了webpack多入口打包的相关资料,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-12-12
  • js实现高精度加减乘除模板的示例代码

    js实现高精度加减乘除模板的示例代码

    这篇文章给大家介绍了如何使用js实现高精度加减乘除模板,文章通过代码示例介绍的非常详细,对大家的学习或工作有一定的帮助,感兴趣的小伙伴可以自己动手尝试一下
    2023-10-10
  • laydate.js日期时间选择插件

    laydate.js日期时间选择插件

    这篇文章主要为大家详细介绍了laydate.js日期时间选择插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • JavaScript 学习笔记(五)

    JavaScript 学习笔记(五)

    今天继续学习JS中的对象,昨天内置对象Global对象和Math对象,今天继续。
    2009-12-12
  • js实现整体缩放页面适配移动端

    js实现整体缩放页面适配移动端

    这篇文章主要介绍了js实现整体缩放页面适配移动端,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • BootStrap glyphicons 字体图标实现方法

    BootStrap glyphicons 字体图标实现方法

    字体图标是在 Web 项目中使用的图标字体。接下来通过本文给大家介绍BootStrap glyphicons 字体图标实现方法,需要的朋友参考下
    2016-05-05
  • 解决Js先触发失去焦点事件再执行点击事件的问题

    解决Js先触发失去焦点事件再执行点击事件的问题

    今天小编就为大家分享一篇解决Js先触发失去焦点事件再执行点击事件的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-08-08
  • js cookie实现记住密码功能

    js cookie实现记住密码功能

    这篇文章主要为大家详细介绍了js cookie实现记住密码功能的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • BootStrap智能表单实战系列(九)表单图片上传的支持

    BootStrap智能表单实战系列(九)表单图片上传的支持

    这篇文章主要介绍了BootStrap智能表单实战系列(九)表单图片上传的支持,介绍如何在生成表单后,可以支持上传图片后可以及时预览图片的功能,需要的朋友可以参考下
    2016-06-06

最新评论