当前位置: 首页 > backend >正文

【Ant Design】解决树形组件面板收起问题

最近在做地图开发的需求时,出现了一个bug:antdv 的树形选择器展开下拉面板时,再点击地图,面板并没有正常收起,而点击其他地方是可以正常收起的。-_-|| 没办法,遇到问题就想办法解决吧
在这里插入图片描述


项目环境及版本

技术栈:Vue2(2.6.12)、ES6、Ant Design of Vue(1.7.8)

运行环境:Node(v14.17.6)、Npm(6.14.15)

一、实现步骤

  1. 绑定 a-tree-select 的 open 属性
    在查看 antdv 官方文档时,tree-select 的api介绍相对较少,想起之前做 Element Plus 的时候,有说树形组件下拉是融合了 select 跟 tree 组件的,说不定能有灵感。果然!在 select 组件介绍找到了可以通过设置 open属性来控制面板的显隐。

在这里插入图片描述

template代码实现:


<a-tree-select :open="areaOpen":dropdown-style="{ maxHeight: '400px', overflow: 'auto' }"class="item-width tree-width"allowClearshowArrowmultipletreeCheckable:maxTagCount="1"v-model="selectedRegion":tree-data="areaTreeData":replaceFields="areaFieldNames"placeholder="区域">
</a-tree-select>
data () {return {/** 区域选择面板是否打开 */areaOpen: false,}
}
  1. 自定义指令

    • 由于检索框有多个树形选择器,所以考虑封装自定义指令实现面板收起。
    • 参数dropdownEl:下拉面板的类名,通过 dropdownClassName 配置
    • 参数openField:绑定的 open 字段名
    • 需要在指令修改 data 里的值,需要在 bind (el, binding, vnode) 写上 vnode 参数
import Vue from 'vue'
Vue.directive('click-outside', {bind (el, binding, vnode) {const vm = vnode.context;const { dropdownEl, openField } = binding.value;// 定义事件处理函数,绑定到 el 上方便解绑el.__clickOutsideHandler__ = function (event) {const dropdownPanels = document.querySelectorAll(`.${dropdownEl}`);// 1. 判断是否点击下拉面板const isClickInsideDropdown = Array.from(dropdownPanels).some(panel => panel.contains(event.target));if (isClickInsideDropdown) return// 2. 如果点击目标元素上,切换状态;否则,关闭面板const isClickOnEl = el.contains(event.target);vm[openField] = isClickInsideDropdown || isClickOnEl ? !vm[openField] : false;}document.addEventListener('click', el.__clickOutsideHandler__);},unbind (el) {// 移除事件监听document.removeEventListener('click', el.__clickOutsideHandler__);delete el.__clickOutsideHandler__;}
});
  1. 指令的使用
    • v-+指令名称即可使用该指令,参数写在后面。
    • 一个参数时直接传,多个参数则传一个对象
<a-tree-select v-click-outside="{dropdownEl: 'areadropdown', openField: 'areaOpen'}"dropdownClassName="custom-tree-dropdown-style areadropdown"
>
</a-tree-select>

二、实现效果

没有录屏软件,之后再补个录屏效果吧,下次一定。

主要是点击面板,open不做改变;点击元素则切换面板收起&显示状态;点击元素外则收起面板。没问题 okok

总结

主要绑定open 属性+自定义指令实现,代码写得太漂亮了忍不住分享一下。(✿◡‿◡)

以上就是解决树形组件面板收起问题啦!下班下班,端午快乐-

在这里插入图片描述

http://www.xdnf.cn/news/10202.html

相关文章:

  • Java多线程文件下载和处理程序
  • 仿真每日一练 | 静力学分析与动力学分析的区别
  • QT 第一讲 --- 基础篇 Qt 基础环境搭建
  • 做销售讲究接地气
  • 【Python-Day 20】揭秘Python变量作用域:LEGB规则与global/nonlocal关键字详解
  • 太阳诱电多层陶瓷电容器的优势和特点
  • springboot java.lang.ClassNotFoundException: dm.jdbc.driver.DmDriver应该如何解决
  • leetcode题解513:找树左下角的值(递归中的回溯处理)!
  • 【CF】Day70——Codeforces Round 896 (Div. 2) CD1 (排列 + 构造 | ⭐思维 + 数学)
  • 20250530-C#知识:抽象类、抽象方法、接口
  • nt!FsRtlFindLargeIndex函数分析计算在那个Mapping[(I)]数组中
  • 基于Java 实现 IM 业务回调
  • Java 之殇:从中流砥柱到“被温柔替代”
  • LeetCode Hot100(动态规划)
  • 04-redis-分布式锁-edisson
  • yum安装nginx后无法通过服务方式启动
  • 企业知识库问答系统避坑指南:检索优化与生成一致性解决方案
  • [ctfshow web入门] web80
  • 2.测试项目启动和研读需求文档
  • js 动画库、2048核心逻辑、面试题add[1][2][3]+4
  • Datatable和实体集合互转
  • 华锐视点助力,虚拟旅游绽放更璀璨光彩​
  • 图书管理系统的设计与实现
  • 北京大学肖臻老师《区块链技术与应用》公开课:06-BTC-网络
  • canoe 排查配置相关【graphics,capl】
  • Python基本运算符
  • python装饰器
  • DSP处理数字信号做什么用的?
  • Unsafe.putOrderedInt与Volatile
  • 驱动灯珠芯片LT3743手册理解