Блог разработчика 1С-Битрикс

Затемнение элементов при наведении на JavaScript

В веб-разработке часто возникает необходимость выделять элементы интерфейса при взаимодействии с пользователем. Один из способов сделать это — затемнение остальных элементов при наведении курсора на один из них. В данной статье мы рассмотрим, как это можно реализовать с помощью HTML, CSS и JavaScript.

Затемнение элементов при наведении

HTML


<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>
    

CSS


.price__item {
    transition: opacity 0.3s;
}

.price__item.dimmed {
    opacity: 0.5; /* Затемнение остальных элементов */
}
    

JavaScript


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');
        });
    });
});
    

Объяснение

  1. HTML: Создаем несколько ссылок с классом price__item.
  2. CSS: Определяем стиль для затемнения элементов при добавлении класса dimmed.
  3. JavaScript:
    • Добавляем обработчик события mouseenter для каждого элемента, который затемняет другие элементы.
    • Добавляем обработчик события mouseleave, чтобы вернуть исходный стиль всем элементам, когда курсор уходит с элемента.

Этот код позволит вам затемнять все элементы, кроме того, на который наведён курсор.

Теги: HTML, CSS, JavaScript, затемнение, элементы, веб-разработка


Валерий Макеев
05.09.2025 17:16
Полный рабочий пример, который можно вставить в один 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>

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

Лендинг

от 3 дней

от 25 000 рублей

Разработка одностраничного сайта на платформе Битрикс

* стоимость зависит от наличия верстки, использования готового решения и т.д.

Техническая поддержка

выполняется с сайтами на основе любых CMS

от 5 000 рублей
Оптимизация производительности действующих интернет-проектов, наполнение и сопровождение, полная техническая поддержка и продвижение в поисковых сетях.

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

Аутсорсинг

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

договорная

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

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