树形选择器VueTreeselect

本文介绍了如何使用Vue-treeselect组件,特别是如何处理数据转换和解决unknown显示的问题。在使用options功能时,需要将数据转化为特定格式的树形结构,若原始数据属性名不同,可通过normalizer函数进行转换。当遇到unknown提示,可能是因为v-model绑定的初始值为空,设置为null即可。若发送请求时仍为null,需检查数据获取逻辑。

官网地址:vue-treeselect 是一个多选组件,具有对 Vue.js嵌套选项支持。

使用方式官网解释的很清楚,无非安装>引入>注册组件>使用组件,并且有HTML与JS两部分可以参考。这里主要对之前自己工作中使用到的功能点不太理解,后面查资料顿悟的记录。

1.options

options:该功能主要传递数组数据,仅接收id、label、children三个属性,也就意味着接收的数据是包含这三个属性的树形数据,如果你跟我一样拿到的是列表数据,则就需要先转化。

需要的结构:

{
  id: '<id>',
  label: '<label>',
  children: [
    {
      id: '<child id>',
      label: '<child label>',
    },
    ...
  ],
}

解决方法:
在这里插入图片描述
在这里插入图片描述

转换后的数据结构确实没错了,但是我们通常拿到的属性名跟官网要求的属性名一般不会一样,所以提供了normalizer函数用于转换.

在这里插入图片描述

在这里插入图片描述

2.unknown解决

如果框里显示unknown,很可能是v-model绑定的值为空,就报错,这时候将绑定的值设置为null就可以。但如果还有另一个问题就是,发送请求时依然为null,或者获取值时为null,可以试下以下判断。

在这里插入图片描述

### Vue2 中使用 TreeSelect 组件实现树形选择 #### 安装依赖 为了在 Vue2 项目中集成 `vue-treeselect`,需通过 npm 或 yarn 进行安装: ```bash npm install --save @riophae/vue-treeselect ``` 或者 ```bash yarn add @riophae/vue-treeselect ``` 此操作会下载并配置所需库文件至项目环境中[^2]。 #### 全局引入与注册 为了让整个应用都能访问到该组件,在项目的入口文件(通常是 `main.js`)中执行如下代码完成全局注册: ```javascript import Treeselect from '@riophae/vue-treeselect' import '@riophae/vue-treeselect/dist/vue-treeselect.css' Vue.component('treeselect', Treeselect); ``` 上述命令不仅导入了 JavaScript 文件还包含了样式表,确保视觉效果正常显示[^1]。 #### 基础用法实例 下面是一个简单的例子展示如何定义数据源以及绑定选项给 `<treeselect>` 标签: ```html <template> <div id="app"> <!-- 使用 v-model 双向绑定 selected 参数 --> <treeselect :options="options" v-model="selected"/> <!-- 显示当前选中的节点名称 --> <p>Selected: {{ getLabel(selected) }}</p> </div> </template> <script> export default { data() { return { // 初始化为空数组表示未做任何选择 selected: [], // 设置可供选择的数据结构 options: [ { id: 'a', label: 'Fruit', children: [ { id: 'aa', label: 'Apple' }, { id: 'ab', label: 'Banana' } ]}, { id: 'b', label: 'Vegetable', children: [ { id: 'ba', label: 'Carrot'}, { id: 'bb', label: 'Broccoli'} ]} ] }; }, methods: { // 辅助函数用于获取指定 ID 的标签名 getLabel(id){ let item = this.findItemById(this.options, id); return item ? item.label : ''; }, findItemById(items, id){ for (let i of items){ if(i.id === id) return i; if(i.children && Array.isArray(i.children)){ let result = this.findItemById(i.children,id); if(result !== null) return result; } } return null; } } } </script> ``` 这段代码展示了基本的选择器设置方式及其交互逻辑。用户可以从预设好的分类列表中挑选项,并实时查看所作选择的结果[^3]。 #### 处理特殊需求 对于更复杂的应用场景,比如希望监听输入变化时获得完整的节点对象而非仅仅是 value,则可以参考官方文档或其他社区贡献者分享的经验来调整事件处理机制[^4]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值