vue3中實現el-tree通過ctrl或shift批量選擇節點并高亮展示

一、看效果:

按住ctrl鍵實現單個多選? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 按住shift實現區間范圍多選? ? ? ? ? ? ? ? ? ? ? ? ? ? ??

? ? ? ? ? ? ? ? ??

二、代碼:

????????vue頁面

<template><el-treeclass="w100%":data="$.treeData"ref="treeTableListRef":props="$.defaultProps"highlight-current:expand-on-click-node="false"key="id":default-expand-all="true"@node-click="(data, node) => $.tableFieldsNodeClick(data, node, treeTableListRef)"><template #default="{ data }"><div style="user-select: none">{{ data.name }}</div></template></el-tree>
</template><script setup lang="ts">
import { useData } from "./hooks/index";
const treeTableListRef = ref();
let { $data: $ } = useData();
onMounted(() => {});
onBeforeMount(() => {window.addEventListener("keydown", handleKeyDown);window.addEventListener("keyup", handleKeyUp);
});
// 按下為true
const handleKeyDown = (event: any) => {// 代表按下的是ctrl鍵if (event.key == "Control") {$.ctrlKeyPressed = true;}// 代表按下的是shift鍵if (event.key == "Shift") {$.shiftKeyPressed = true;}
};
// 釋放為false
const handleKeyUp = (event: any) => {// 代表按下的是ctrl鍵if (event.key == "Control") {$.ctrlKeyPressed = false;}// 代表按下的是shift鍵if (event.key == "Shift") {$.shiftKeyPressed = false;}
};
</script><style scoped lang="scss">
</style>

????????引入的hooks文件,index.ts

export function useData() {const $data: any = reactive({ctrlKeyPressed: false,shiftKeyPressed: false,shiftKeyFelid: [],defaultProps: {children: "children",label: "name",},treeData: [{name: '一級1',id: 1,children: [{name: '二級1',id: 2,children: [{name: '三級1',id: 2,}, {name: '三級2',id: 3,}, {name: '三級3',id: 4,}, {name: '三級4',id: 5,}, {name: '三級5',id: 6,}]}, {name: '二級2',id: 3,}, {name: '二級3',id: 4,}, {name: '二級4',id: 5,}, {name: '二級5',id: 6,}]}, {name: '一級2',id: 7,children: [{name: '二級1',id: 8,}, {name: '二級2',id: 9,}, {name: '二級3',id: 10,}, {name: '二級4',id: 11,}, {name: '二級5',id: 12,}]}],selectNodes: []})// 節點選中事件$data.tableFieldsNodeClick = (nodeData: any, node: any, treeTableListRef: any) => {const nodes = treeTableListRef.store._getAllNodes();//所有node節點const ishas = $data.selectNodes.includes(node.id)// 遞歸遍歷節點數組進行ID存放function addSelectId(arr: any) {for (const item of arr) {$data.selectNodes.push(item.id)if (Array.isArray(item.children) && item.children.length) {addSelectId(item.children)}}}// 遞歸遍歷刪除節點idfunction delSelectId(arr: any) {for (const item of arr) {const index = $data.selectNodes.findIndex((x: any) => x == item.id);$data.selectNodes.splice(index, 1);if (Array.isArray(item.children) && item.children.length) {delSelectId(item.children);}}}// 按住了ctrl鍵,可以進行單個多選if ($data.ctrlKeyPressed) {// 如果為true代表當前選中的節點已存在if (ishas) {// 查找當前選中的節點的索引const index = $data.selectNodes.findIndex((x: any) => x == node.id);// 刪除父節點$data.selectNodes.splice(index, 1);// 刪除子節點if (Array.isArray(node.childNodes) && node.childNodes.length) {deleteSelectId(node.childNodes);}} else {// 否則當前選中的節點不存在,就加入到已選節點數組序列$data.selectNodes.push(node.id)// 防止選中的是父節點,就需要遞歸將子節點加入if (Array.isArray(node.childNodes) && node.childNodes.length) {addSelectId(node.childNodes);}}node.isCurrent = !node.isCurrent;// 按下了shift鍵,可以進行范圍多選} else if ($data.shiftKeyPressed) {// 先清空$data.selectNodes = []// 將當前節點放入$data.selectNodes.push(node.id)$data.shiftKeyFelid.push(node.id);if ($data.shiftKeyFelid.length > 1) {// 首索引const sIndex = nodes.findIndex((x: any) => x.id == $data.shiftKeyFelid[0])// 尾索引const eIndex = nodes.findIndex((x: any) => x.id == $data.shiftKeyFelid[$data.shiftKeyFelid.length - 1]);// 根據首尾索引,存入中間節點const s = sIndex < eIndex ? sIndex : eIndex //取小值當開頭索引const e = sIndex < eIndex ? eIndex : sIndex//取大值當結尾索引for (let i = s; i < e; i++) {// 放入該區間節點id$data.selectNodes.push(nodes[i].id);}}} else {// 否則就是單機選擇$data.shiftKeyFelid = [];$data.selectNodes = [];$data.selectNodes = [node.id];}// 下面是對已選中的節點,進行高亮展示// 通過控制elementui中節點上的isCurrent屬性// isCurrent為true是高亮,否則取消高亮for (const item of nodes) {if ($data.selectNodes.includes(item.id)) {item.isCurrent = true;} else {item.isCurrent = false;}}};return {$data: $data}
}

三、注意:

? ? ? ? 1、重點是要獲取當前所選節點數組

????????2、通過循環節點數組來更新nodes節點中isCurrent屬性,控制高亮

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/207890.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/207890.shtml
英文地址,請注明出處:http://en.pswp.cn/news/207890.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Unity中Batching優化的靜態合批

文章目錄 前言一、靜態合批的規則1、模型使用同一個材質2、勾選靜態合批3、對于靜態合批后的Mesh頂點總數&#xff0c;不超過2^16^即可以使用同一批次&#xff0c;超過則會開啟一個新的批次4、對與使用同一材質的不同模型間&#xff0c;紋理貼圖的問題&#xff0c;我們可以通過…

數據可視化工具選擇:功能、易用性與安全性

作為一名數據可視化大屏設計師&#xff0c;我深知選擇一款合適的數據可視化工具對于提高工作效率和呈現效果的重要性。下面&#xff0c;我將從真正對我們數據可視化大屏設計師有用的角度為大家介紹選擇數據可視化工具的一些必要條件和要求。 1. 功能強大與靈活定制 首先&…

高并發場景下的httpClient使用優化技巧

1. 背景 我們有個業務&#xff0c;會調用其他部門提供的一個基于http的服務&#xff0c;日調用量在千萬級別。使用了httpclient來完成業務。之前因為qps上不去&#xff0c;就看了一下業務代碼&#xff0c;并做了一些優化&#xff0c;記錄在這里。 先對比前后&#xff1a;優化…

如何做好口譯服務,同傳和交傳哪個服務好

隨著中國經濟的蓬勃發展和綜合實力的不斷增強&#xff0c;中國與世界各國的交流也日益頻繁。口譯作為對外交流的橋梁與紐帶&#xff0c;需求量與日俱增&#xff0c;其重要性不言而喻。那么&#xff0c;如何做好口譯服務呢&#xff1f;是同傳還是交傳更好呢&#xff1f; 業內專家…

滲透測試工具AWVS的全面解析

在當今的數字化時代&#xff0c;網絡安全已經成為了企業和個人必須關注的重要問題。為了確保網絡的安全&#xff0c;我們需要使用各種工具和技術進行檢測和防護。其中&#xff0c;滲透測試是一種非常重要的方法&#xff0c;它可以幫助我們發現網絡中的安全漏洞&#xff0c;并采…

機器人純阻抗控制接觸剛性環境

問題描述 在機器人學中&#xff0c;阻抗控制是一種常用的控制策略&#xff0c;用于管理機器人在與環境交互時的運動和力。阻抗控制背后的關鍵概念是將環境視為導納&#xff0c;而將機器人視為阻抗。 純阻抗控制接觸剛性環境時&#xff0c;機器人的行為方式主要受其阻抗參數的…

表單小程序作用體現在哪

表單的用途非常廣泛&#xff0c;它是線上收集信息或用戶預約/需求服務的重要方式&#xff0c;對商家來說如今線上平臺非常多&#xff0c;生意開展的形式也越來越多&#xff0c;比如常見的預約、報名、收款、產品支付等都可以通過表單實現。 接下來啊讓我們看看通過【雨科】平臺…

家用智能門鎖——智能指紋鎖方案

智能指紋鎖產品功能&#xff1a; 1&#xff1a;指紋識別技術&#xff1a;光學傳感器、半導體傳感器或超聲波傳感器等。 2&#xff1a;指紋容量&#xff1a;智能指紋鎖可以存儲的指紋數量&#xff0c;通常在幾十到幾百個指紋之間。 3&#xff1a;解鎖時間&#xff1a;指紋識別和…

【力扣100】8.找到字符串中所有字母異位詞

添加鏈接描述 class Solution:def findAnagrams(self, s: str, p: str) -> List[int]:sildingstrresult[]p.join(sorted(p))for i in range(len(s)):if len(sildingstr)<len(p):sildingstrsildingstrs[i]# print(sildingstr)if len(sildingstr)len(p):sort_sildingstr.j…

Android開發常用工具類集合

目錄 DownloadGradleAPIsActivity 相關 -> ActivityUtils.java -> DemoAdaptScreen 相關 -> AdaptScreenUtils.java -> DemoApp 相關 -> AppUtils.java -> Demo欄相關 -> BarUtils.java -> Demo亮度相關 -> BrightnessUtils.java -> DemoBus 相關…

身份認證技術

身份認證是對系統的用戶進行有效性、真實性驗證。 1&#xff0e;口令認證方式 使用口令認證方式&#xff0c;用戶必須具有一個唯一的系統標識&#xff0c;并且保證口令在系統的使用和存儲過程中是安全的&#xff0c;同時口令在傳輸過程中不能被竊取、替換。另外特別要注意的是在…

解決:During handling of the above exception, another exception occurred

解決&#xff1a;During handling of the above exception, another exception occurred 文章目錄 解決&#xff1a;During handling of the above exception, another exception occurred背景報錯問題報錯翻譯報錯位置代碼報錯原因解決方法參考內容&#xff1a;今天的分享就到…

numpy數據讀取保存及速度測試

目錄 數據保存及讀取 速度比對測試 數據保存及讀取 代碼示例&#xff1a; # 導入必要的庫 import numpy as np # 生成測試數據 arr_disk np.arange(8) # 打印生成能的數據 print(arr_disk) # numpy保存數據到本地 np.save("arr_disk", arr_disk) # 加載本地數據…

排序算法-插入/希爾排序

1 插入排序 1.1基本思想&#xff1a; 直接插入排序是一種簡單的插入排序法&#xff0c;其基本思想是&#xff1a;把待排序的記錄按其關鍵碼值的大小逐個插入到一個已經排好序的有序序列中&#xff0c;直到所有的記錄插入完為止&#xff0c;得到一個新的有序序列 。 1.2直…

CentOS7.0 下rpm安裝MySQL5.5.60

下載 下載路徑: MySQL :: Download MySQL Community Server -->looking for the latest GA version-->5.5.60 此壓縮包中有多個rpm包 有四個不是必須的,只需安裝這三個 MySQL-server-5.5.60-1.el6.x86_64 MySQL-devel-5.5.60-1.el6.x86_64 MySQL-client-5.5.60-1.el6.x8…

pymysql insert dataframe 遇到 nan 值

def get_db_conn():"""MYSQL連接"""host Config.MYSQL["host"]pwd Config.MYSQL["pwd"]user Config.MYSQL["user"]port Config.MYSQL["port"]database Config.MYSQL["database"]conn p…

智能淘客查券返利機器人與導購app:差異與優勢

智能淘客查券返利機器人與導購app&#xff1a;差異與優勢 在數字化購物的時代&#xff0c;我們發現越來越多的工具幫助我們省錢和賺錢。其中&#xff0c;智能淘客查券返利機器人和導購app是兩種非常受歡迎的工具。然而&#xff0c;這兩種工具在運作方式、功能以及效果上存在明…

代碼隨想Day 31 | 455.分發餅干、376. 擺動序列 、53. 最大子序和

455.分發餅干 這道題目我的思路就是&#xff0c;先滿足小胃口的小朋友&#xff0c;這樣能夠滿足更多人&#xff0c;首先把兩個數組排序&#xff0c;然后依次對比&#xff0c;不滿足某個胃口小的小朋友就一直給更大的餅干&#xff0c;詳細代碼如下&#xff1a; class Solution…

【js】js實現多個視頻連續播放:

文章目錄 一、效果&#xff1a;二、實現&#xff1a; 一、效果&#xff1a; 二、實現&#xff1a; <!DOCTYPE html> <html> <head><title>Video Player</title><style>#progressBar { width: 800px;height: 20px;background-color: #dd…

【Vulnhub 靶場】【Momentum: 2】【簡單】【20210628】

1、環境介紹 靶場介紹&#xff1a;https://www.vulnhub.com/entry/momentum-2,702/ 靶場下載&#xff1a;https://download.vulnhub.com/momentum/Momentum2.ova 靶場難度&#xff1a;簡單 發布日期&#xff1a;2021年06月28日 文件大小&#xff1a;698 MB 靶場作者&#xff1…