VxeGRid树形表格编辑难点

引言


在多级BOM的情况下,会有键盘导航+编辑的需求。 此时的你把VxeGrid文档中的单元格编辑按键操作树形懒加载组件的代码组合一起,效果如下。

功能展示


切记给editConfig加上autoClear

当点击表格之外或者非编辑列之后,是否自动清除单元格的激活状态

此时没任何问题,可以正常导航和编辑。

但展开树形图时,在进行导航编辑.你会发现会有两个高亮,及父表格和子表格。效果如下

解析


回想下之前提及的那个API:autoClear.只有在表格外或非编辑列才会清除Active状态。既然是展开行,所以肯定是在同一个表格内,所以才会导致出现这个情况。

既然找到问题点了,那思路就是点击内部表格时,清除外部表格的Active.

我使用的相关api:

js 复制代码
cell-selected: 只对 mouse-config.selected 配置时有效,单元格被选中时会触发该事件 

 /**
   * 用于 mouse-config.selected,获取选中的单元格信息
   */
  getSelectedCell(): {
    row: D
    column: VxeTableDefines.ColumnInfo<D>
  }
  
   /**
   * 手动清除单元格选中状态
   */
  clearSelected(): Promise<any>
  

代码如下

js 复制代码
const tableRef = ref<VxeGridInstance | null>(null)

const handleExpandedTableCellSelected = async () => {
  // getSelectedCell获取外部table的选中cell,再在内部取消外部table的选中
  const $grid = tableRef.value
  const selectedCell = $grid?.getSelectedCell()
  // console.log('外部table selectedCell', selectedCell)
  //如果内部table有选中cell,则取消外部table的选中
  if (selectedCell) {
    await $grid?.clearSelected()
  }
}

<vxe-grid
    ref="expandGridRef"
    @cell-selected="handleExpandedTableCellSelected"    
>
相关推荐
我叫黑大帅9 分钟前
前端如何利用 GitHub Actions 自动构建并发布到 GitHub Pages?
前端·面试·github
smallLabel13 分钟前
记一次 OpenClaw 飞书插件接入填坑指南: Error: spawn EINVAL
前端
zzjyr15 分钟前
react前端项目 fetch原生 与 umijs request 四种请求区别
前端
我叫黑大帅15 分钟前
前端总说的防抖与节流到底是什么?
前端·javascript·面试
小时前端16 分钟前
微信小程序选不了本地文件?用 web-view + H5 一招搞定
前端·微信小程序·uni-app
71Ove16 分钟前
告别手写字符串!UniApp 路由全自动类型生成工具
前端
掘金安东尼18 分钟前
从平面到空间:用 React Three Fiber 构建 3D 产品网格
前端·javascript·面试
小时前端18 分钟前
HTTPS 页面加载 HTTP 脚本被拦?同源代理来救场
前端·https
用户6837093595519 分钟前
在 Rokid AR 眼镜里玩消消乐:基于 Unity 2022 LTS + UXR 3.0 SDK 的轻量级 AR 游戏尝试
前端
zzjyr20 分钟前
@umijs/max 中导出的 request 方法,如何实现 GET/POST/PUT/DELETE 这四种核心请求
前端