В HTML каждое событие мыши имеет доступ к базовому элементу. Это легко сделать с помощью JavaScript, и в HTML5 есть замечательная функция classList (спасибо Эрику из Chromium), которая позволяет легко добавлять и удалять классы из DOM.
Прежде всего, вы можете добиться этого с помощью скриптов содержания Google Chrome . Алгоритм довольно прост: вы сохраняете указатель на последний посещенный DOM и просто добавляете / удаляете класс при посещении другого элемента DIV.
В вашем manifest.json Мы определим CSS и JS-инъекции для каждой страницы, которую мы видим.
...
...
"content_scripts": [
{
"matches": ["http://*/*"],
"css": ["core.css"],
"js": ["core.js"],
"run_at": "document_end",
"all_frames": true
}
]
...
...
Теперь давайте рассмотрим наш core.js , я включил несколько комментариев, чтобы объяснить, что происходит:
// Unique ID for the className.
var MOUSE_VISITED_CLASSNAME = 'crx_mouse_visited';
// Previous dom, that we want to track, so we can remove the previous styling.
var prevDOM = null;
// Mouse listener for any move event on the current document.
document.addEventListener('mousemove', function (e) {
var srcElement = e.srcElement;
// Lets check if our underlying element is a DIV.
if (srcElement.nodeName == 'DIV') {
// For NPE checking, we check safely. We need to remove the class name
// Since we will be styling the new one after.
if (prevDOM != null) {
prevDOM.classList.remove(MOUSE_VISITED_CLASSNAME);
}
// Add a visited class name to the element. So we can style it.
srcElement.classList.add(MOUSE_VISITED_CLASSNAME);
// The current element is now the previous. So we can remove the class
// during the next iteration.
prevDOM = srcElement;
}
}, false);
Теперь давайте посмотрим на простой core.css для стилей:
.crx_mouse_visited {
background-color: #bcd5eb !important;
outline: 1px solid #5166bb !important;
}
Таким образом, вы заметите, что все ваши div'ы будут в состоянии "зависания", аналогично тому, что происходит при посещении инспектора браузера при проверке элементов.