Добавление эффекта затенения при наведении на элемент в JavaScript

Внимание! Работает режим премодерации. Все сообщения публикуются после проверки!
Страницы: 1
Ответить
RSS
Добавление эффекта затенения при наведении на элемент в JavaScript
Затемнение элементов при наведении на JavaScript

В веб-разработке часто возникает необходимость выделять элементы  интерфейса при взаимодействии с пользователем. Один из способов сделать  это — затемнение остальных элементов при наведении курсора на один из  них. В данной статье мы рассмотрим, как это можно реализовать с помощью  HTML, CSS и JavaScript.
Изменено: Валерий Макеев - 29.09.2025 15:13:35
Полный рабочий пример, который можно вставить в один HTML-файл. Этот код затемняет все элементы с классом price__item, кроме того, на который наведён курсор, создавая эффект визуального выделения активного элемента.
Код
<!DOCTYPE html>
<html lang="ru">
<head>
    <meta charset="UTF-8">
    <title>Затемнение при наведении</title>
    <style>
        .price__item {
            display: block;
            padding: 15px;
            margin: 10px 0;
            background-color: #f0f0f0;
            text-align: center;
            text-decoration: none;
            color: #000;
            border-radius: 5px;
            transition: opacity 0.3s;
        }

        .price__item.dimmed {
            opacity: 0.5;
        }
    </style>
</head>
<body>
    <a href="#" class="price__item">Item 1</a>
    <a href="#" class="price__item">Item 2</a>
    <a href="#" class="price__item">Item 3</a>
    <a href="#" class="price__item">Item 4</a>

    <script>
        const items = document.querySelectorAll('.price__item');

        items.forEach(item => {
            item.addEventListener('mouseenter', () => {
                items.forEach(el => {
                    if (el !== item) {
                        el.classList.add('dimmed');
                    }
                });
            });

            item.addEventListener('mouseleave', () => {
                items.forEach(el => {
                    el.classList.remove('dimmed');
                });
            });
        });
    </script>
</body>
</html>
Страницы: 1
Ответить
Форма ответов
Текст сообщения*
Перетащите файлы
Ничего не найдено
Файл
 

Стоимость услуг по разработке и сопровождению сайтов на 1C-Битрикс

Модули и компоненты для «1С-Битрикс»

оценка производится на основе предоставленного Технического Задания

от 20 000 рублей
Разработка дополнительных модулей для 1С-Битрикс, расширение функционала, внедрение любых решений, требующихся для выполнения ваших бизнес-задач.

* стоимость зависит от конкретной задачи, ее объема и сложности выполняемых работ.

Аутсорсинг

готов помочь, если нет времени

договорная

Могу взять на себя работы по full-stack

* на основе готовой верстки

Разработка интернет-магазина с готовой версткой

от 4 недель

от 90 000 рублей

* указана минимальная стоимость. Стоимость выбранной лицензии «1С-Битрикс» оплачивается отдельно.