mouseover dev
This commit is contained in:
@@ -181,15 +181,15 @@ export const I18N = {
|
|||||||
zh: `鼠标悬停`,
|
zh: `鼠标悬停`,
|
||||||
en: `Mouseover`,
|
en: `Mouseover`,
|
||||||
},
|
},
|
||||||
mk_control: {
|
mk_ctrlKey: {
|
||||||
zh: `Control + 鼠标悬停`,
|
zh: `Control + 鼠标悬停`,
|
||||||
en: `Control + Mouseover`,
|
en: `Control + Mouseover`,
|
||||||
},
|
},
|
||||||
mk_shift: {
|
mk_shiftKey: {
|
||||||
zh: `Shift + 鼠标悬停`,
|
zh: `Shift + 鼠标悬停`,
|
||||||
en: `Shift + Mouseover`,
|
en: `Shift + Mouseover`,
|
||||||
},
|
},
|
||||||
mk_alt: {
|
mk_altKey: {
|
||||||
zh: `Alt + 鼠标悬停`,
|
zh: `Alt + 鼠标悬停`,
|
||||||
en: `Alt + Mouseover`,
|
en: `Alt + Mouseover`,
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -164,9 +164,9 @@ export const OPT_STYLE_USE_COLOR = [
|
|||||||
|
|
||||||
export const OPT_MOUSEKEY_DISABLE = "mk_disable";
|
export const OPT_MOUSEKEY_DISABLE = "mk_disable";
|
||||||
export const OPT_MOUSEKEY_NONE = "mk_none";
|
export const OPT_MOUSEKEY_NONE = "mk_none";
|
||||||
export const OPT_MOUSEKEY_CONTROL = "mk_control";
|
export const OPT_MOUSEKEY_CONTROL = "mk_ctrlKey";
|
||||||
export const OPT_MOUSEKEY_SHIFT = "mk_shift";
|
export const OPT_MOUSEKEY_SHIFT = "mk_shiftKey";
|
||||||
export const OPT_MOUSEKEY_ALT = "mk_alt";
|
export const OPT_MOUSEKEY_ALT = "mk_altKey";
|
||||||
export const OPT_MOUSEKEY_ALL = [
|
export const OPT_MOUSEKEY_ALL = [
|
||||||
OPT_MOUSEKEY_DISABLE,
|
OPT_MOUSEKEY_DISABLE,
|
||||||
OPT_MOUSEKEY_NONE,
|
OPT_MOUSEKEY_NONE,
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ import {
|
|||||||
OPT_STYLE_FUZZY,
|
OPT_STYLE_FUZZY,
|
||||||
SHADOW_KEY,
|
SHADOW_KEY,
|
||||||
OPT_MOUSEKEY_DISABLE,
|
OPT_MOUSEKEY_DISABLE,
|
||||||
|
OPT_MOUSEKEY_NONE,
|
||||||
} from "../config";
|
} from "../config";
|
||||||
import Content from "../views/Content";
|
import Content from "../views/Content";
|
||||||
import { updateFetchPool, clearFetchPool } from "./fetch";
|
import { updateFetchPool, clearFetchPool } from "./fetch";
|
||||||
@@ -38,7 +39,6 @@ export class Translator {
|
|||||||
"iframe",
|
"iframe",
|
||||||
];
|
];
|
||||||
_eventName = genEventName();
|
_eventName = genEventName();
|
||||||
_keydownNow = "";
|
|
||||||
|
|
||||||
// 显示
|
// 显示
|
||||||
_interseObserver = new IntersectionObserver(
|
_interseObserver = new IntersectionObserver(
|
||||||
@@ -241,32 +241,16 @@ export class Translator {
|
|||||||
node.addEventListener("mouseover", this._handleMouseover);
|
node.addEventListener("mouseover", this._handleMouseover);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// 监听键盘事件
|
|
||||||
window.addEventListener("keydown", this._handleKeydown);
|
|
||||||
window.addEventListener("keyup", this._handleKeyup);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
_handleMouseover = (e) => {
|
_handleMouseover = (e) => {
|
||||||
if (
|
const key = this._setting.mouseKey.slice(3);
|
||||||
this._keydownNow &&
|
if (this._setting.mouseKey === OPT_MOUSEKEY_NONE || e[key]) {
|
||||||
this._setting?.mouseKey?.endsWith(this._keydownNow)
|
|
||||||
) {
|
|
||||||
e.target.removeEventListener("mouseover", this._handleMouseover);
|
e.target.removeEventListener("mouseover", this._handleMouseover);
|
||||||
this._render(e.target);
|
this._render(e.target);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
_handleKeydown = (e) => {
|
|
||||||
console.log("keydown", e.key);
|
|
||||||
this._keydownNow = e.key.toLowerCase();
|
|
||||||
};
|
|
||||||
|
|
||||||
_handleKeyup = (e) => {
|
|
||||||
console.log("keyup", e.key);
|
|
||||||
this._keydownNow = "";
|
|
||||||
};
|
|
||||||
|
|
||||||
_unRegister = () => {
|
_unRegister = () => {
|
||||||
// 解除节点变化监听
|
// 解除节点变化监听
|
||||||
this._mutaObserver.disconnect();
|
this._mutaObserver.disconnect();
|
||||||
@@ -290,11 +274,6 @@ export class Translator {
|
|||||||
node.querySelector(APP_LCNAME)?.remove();
|
node.querySelector(APP_LCNAME)?.remove();
|
||||||
});
|
});
|
||||||
|
|
||||||
// 解除监听键盘
|
|
||||||
window.removeEventListener("keydown", this._handleKeydown);
|
|
||||||
window.removeEventListener("keyup", this._handleKeyup);
|
|
||||||
this._keydownNow = "";
|
|
||||||
|
|
||||||
// 清空节点集合
|
// 清空节点集合
|
||||||
this._rootNodes.clear();
|
this._rootNodes.clear();
|
||||||
this._tranNodes.clear();
|
this._tranNodes.clear();
|
||||||
|
|||||||
Reference in New Issue
Block a user