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

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

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

Разработка корпоративного сайта

от 7 дней

от 40 000 рублей

Разработка сайта без системы оплаты заказов через корзину

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

Лендинг

от 3 дней

от 25 000 рублей

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

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

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

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

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

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