# TreeSelect 分类选择 ### 引入 ``` javascript import Vue from 'vue'; import { TreeSelect } from 'vant'; Vue.use(TreeSelect); ``` ## 代码演示 ### 单选模式 `item`为分类显示所需的数据,数据格式见下方示例。`main-active-index`表示左侧高亮选项的索引,`active-id`表示右侧高亮选项的 id ```html ``` ```javascript export default { data() { return { items, activeId: 1, activeIndex: 0 }; } } ``` ### 多选模式 `active-id`为数组格式时,可以选中多个右侧选项 ```html ``` ```javascript export default { data() { return { items, activeIds: [1, 2], activeIndex: 0 }; } } ``` ### 自定义内容 通过`content`插槽可以自定义右侧区域的内容 ```html ``` ```js export default { data() { return { activeIndex: 0, items: [{ text: '分组 1' }, { text: '分组 2' }] } } } ``` ## API ### Props | 参数 | 说明 | 类型 | 默认值 | 版本 | |------|------|------|------|------| | items | 分类显示所需的数据 | *Item[]* | `[]` | - | | height | 高度,默认单位为 px | *string \| number* | `300` | - | | main-active-index | 左侧选中项的索引 | *number* | `0` | - | | active-id | 右侧选中项的 id,支持传入数组 | *string \| number \| (string \| number)[]* | `0` | - | | max | 右侧项最大选中个数 | *number* | *Infinity* | 2.2.0 | ### Events | 事件名 | 说明 | 回调参数 | |------|------|------| | click-nav | 点击左侧导航时触发 | index:被点击的导航的索引 | | click-item | 点击右侧选择项时触发 | data: 该点击项的数据 | ### Slots | 名称 | 说明 | |------|------| | content | 自定义右侧区域内容 | ### Item 数据结构 `items` 整体为一个数组,数组内包含一系列描述分类的对象。 每个分类里,text 表示当前分类的名称。children 表示分类里的可选项,为数组结构,id 被用来唯一标识每个选项 ```javascript [ { // 导航名称 text: '所有城市', // 导航名称右上角徽标 info: 3, // 该导航下所有的可选项 children: [ { // 名称 text: '温州', // id,作为匹配选中状态的标识 id: 1, // 禁用选项 disabled: true }, { text: '杭州', id: 2 } ] } ] ```