fix(app): 优化阻止默认右键菜单处理逻辑,处理每个元素
This commit is contained in:
12
src/App.vue
12
src/App.vue
@@ -53,18 +53,24 @@ const themeVars = useThemeVars();
|
|||||||
*/
|
*/
|
||||||
function handleContextMenu(event) {
|
function handleContextMenu(event) {
|
||||||
|
|
||||||
let element = event.target;
|
let elements = event.composedPath();
|
||||||
let classValue = '';
|
let classValue = '';
|
||||||
let classRegExp = /(__code__|n-code|n-input|n-input-number|n-select)/;
|
let classRegExp = /(n-code|n-input|n-input-number|n-ol|n-select)/;
|
||||||
|
|
||||||
// 排除按住 Ctrl 键时
|
// 排除按住 Ctrl 键时
|
||||||
if (event.ctrlKey) {
|
if (event.ctrlKey) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (let i = 0; i < elements.length; i++) {
|
||||||
|
|
||||||
|
let element = elements[i];
|
||||||
|
|
||||||
// 获取元素 class 信息
|
// 获取元素 class 信息
|
||||||
if (element instanceof HTMLElement) {
|
if (element instanceof HTMLElement) {
|
||||||
classValue = element.classList.value;
|
classValue = element.classList.value;
|
||||||
|
} else {
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 排除输入框元素
|
// 排除输入框元素
|
||||||
@@ -77,6 +83,8 @@ function handleContextMenu(event) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user