TreeSelect 分类选择

引入

app.jsonindex.json中引入组件,详细介绍见快速上手

"usingComponents": {
  "van-tree-select": "path/to/@vant/weapp/dist/tree-select/index"
}

代码演示

单选模式

可以在任意位置上使用 van-tree-select 标签。传入对应的数据即可。 此组件支持单选或多选,具体行为完全基于事件 click-item 的实现逻辑如何为属性 active-id 赋值,当 active-id 为数组时即为多选状态。

<van-tree-select
  items="{{ items }}"
  main-active-index="{{ mainActiveIndex }}"
  active-id="{{ activeId }}"
  bind:click-nav="onClickNav"
  bind:click-item="onClickItem"
/>
Page({
  data: {
    mainActiveIndex: 0,
    activeId: null
  },

  onClickNav({ detail = {} }) {
    this.setData({
      mainActiveIndex: detail.index || 0
    });
  },

  onClickItem({ detail = {} }) {
    const activeId = this.data.activeId === detail.id ? null : detail.id;

    this.setData({ activeId });
  }
});

多选模式

<van-tree-select
  items="{{ items }}"
  main-active-index="{{ mainActiveIndex }}"
  active-id="{{ activeId }}"
  max="{{ max }}"
  bind:click-nav="onClickNav"
  bind:click-item="onClickItem"
/>
Page({
  data: {
    mainActiveIndex: 0,
    activeId: [],
    max: 2
  },

  onClickNav({ detail = {} }) {
    this.setData({
      mainActiveIndex: detail.index || 0
    });
  },

  onClickItem({ detail = {} }) {
    const { activeId } = this.data;

    const index = activeId.indexOf(detail.id);
    if (index > -1) {
      activeId.splice(index, 1);
    } else {
      activeId.push(detail.id);
    }

    this.setData({ activeId });
  }
});

自定义内容

<van-tree-select
  items="{{ items }}"
  main-active-index="{{ mainActiveIndex }}"
  active-id="{{ activeId }}"
  bind:click-nav="onClickNav"
  bind:click-item="onClickItem"
>
  <image src="https://img.yzcdn.cn/vant/apple-1.jpg" slot="content" />
<van-tree-select/>

API

Props

参数 说明 类型 默认值 版本
items 分类显示所需的数据 Array [] -
main-active-index 左侧选中项的索引 number 0 -
active-id 右侧选中项的 id支持传入数组 string | number | Array 0 -
max 右侧项最大选中个数 number Infinity -

Events

事件名 说明 回调参数
bind:click-nav 左侧导航点击时,触发的事件 event.detail.index被点击的导航的索引
bind:click-item 右侧选择项被点击时,会触发的事件 event.detail: 该点击项的数据

Slots

名称 说明
content 自定义右侧区域内容,如果存在 items则插入在顶部

items 数据结构

items 整体为一个数组,数组内包含一系列描述分类的对象

每个分类里text 表示当前分类的名称。children 表示分类里的可选项为数组结构id 被用来唯一标识每个选项

[
  {
    // 导航名称
    text: '所有城市',
    // 禁用选项
    disabled: false,
    // 该导航下所有的可选项
    children: [
      {
        // 名称
        text: '温州',
        // id作为匹配选中状态的标识
        id: 1,
        // 禁用选项
        disabled: true
      },
      {
        text: '杭州',
        id: 2
      }
    ]
  }
]

外部样式类

类名 说明
main-item-class 左侧选项样式类
content-item-class 右侧选项样式类
main-active-class 左侧选项选中样式类
content-active-class 右侧选项选中样式类
main-disabled-class 左侧选项禁用样式类
content-disabled-class 右侧选项禁用样式类