<MyRusakov.ru />

WordPress 6 с Нуля до Гуру

WordPress 6 с Нуля до Гуру

Этот курс научит Вас созданию самых разных сайтов на самой популярной в мире CMS - WordPress. Вы увидите установку и настройку локального сервера, разбор каждой настройки, каждой кнопки и каждого пункта меню в панели WordPress.

Также Вы получите и всю практику, поскольку прямо в курсе с нуля создаётся полноценный Интернет-магазин, который затем публикуется в Интернете. И всё это прямо на Ваших глазах.

Помимо уроков к курсу идут упражнения для закрепления материала.

И, наконец, к курсу идёт ценнейший Бонус по тому, как используя ChatGPT и создавая контент для сайта, можно выйти на пассивный доход. Вы наглядно увидите, как зарегистрироваться в ChatGPT (в том числе, и если Вы из России), как правильно выбрать тему для сайта, как правильно генерировать статьи для него(чтобы они индексировались поисковыми системами) и как правильно монетизировать трафик на сайте.

Подробнее
Подписка

Подпишитесь на мой канал на YouTube, где я регулярно публикую новые видео.

YouTube Подписаться

Подписавшись по E-mail, Вы будете получать уведомления о новых статьях.

Подписка Подписаться

Добавляйтесь ко мне в друзья ВКонтакте! Отзывы о сайте и обо мне оставляйте в моей группе.

Мой аккаунт Мой аккаунт Моя группа
Опрос

Какая тема Вас интересует больше?

Отображение маршрута между двумя точками на карте

Отображение маршрута между двумя точками на карте

Приветствую, дорогие читатели! В сегодняшней статье мы рассмотрим, как реализовать фильтры на карте, используя JavaScript и библиотеку Leaflet. Мы добавим поиск по местоположению и категории объектов, что поможет пользователям легко находить нужные точки на карте.

Подключение карты и данных

Для начала создадим HTML-страницу и подключим Leaflet:

<!DOCTYPE html>
<html lang="ru">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Фильтры на карте</title>
    <link rel="stylesheet" href="https://unpkg.com/leaflet@1.9.4/dist/leaflet.css" />
    <style>
        #map { height: 500px; }
        .controls { margin: 10px; }
    </style>
</head>
<body>
    <h1>Фильтр объектов на карте</h1>
    <div class="controls">
        <input type="text" id="search" placeholder="Введите название...">
        <select id="category">
            <option value="all">Все</option>
            <option value="restaurant">Рестораны</option>
            <option value="hotel">Отели</option>
        </select>
        <button onclick="applyFilters()">Фильтровать</button>
    </div>
    <div id="map"></div>
    <script src="https://unpkg.com/leaflet@1.9.4/dist/leaflet.js"></script>
    <script>
        const map = L.map('map').setView([55.751, 37.617], 12);

        L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
            attribution: 'Map data \u00a9 OpenStreetMap contributors',
            maxZoom: 18,
        }).addTo(map);

        const places = [
            { coords: [55.75, 37.61], name: "Ресторан 1", category: "restaurant" },
            { coords: [55.76, 37.62], name: "Отель 1", category: "hotel" },
            { coords: [55.74, 37.63], name: "Ресторан 2", category: "restaurant" }
        ];

        let markers = [];

        function displayMarkers(data) {
            markers.forEach(marker => map.removeLayer(marker));
            markers = data.map(place => {
                return L.marker(place.coords).addTo(map).bindPopup(place.name);
            });
        }

        function applyFilters() {
            const searchText = document.getElementById("search").value.toLowerCase();
            const category = document.getElementById("category").value;
            const filtered = places.filter(place =>
                (category === "all" || place.category === category) &&
                place.name.toLowerCase().includes(searchText)
            );
            displayMarkers(filtered);
        }

        displayMarkers(places);
    </script>
</body>
</html>

Разбор кода

  1. Создаём карту и добавляем базовый слой OpenStreetMap.

  2. Добавляем данные о местах, храня их в массиве объектов.

  3. Рисуем маркеры и обновляем их в зависимости от фильтров.

  4. Фильтруем по названию и категории с помощью input и select.

Итог

Теперь карта умеет фильтровать объекты по названию и категории, что делает её удобнее для пользователей!

Хотите глубже освоить JavaScript? Рекомендую курс "Программирование на JavaScript с Нуля до Гуру 2.0", где вы найдёте ещё больше полезных техник и приёмов!

Копирование материалов разрешается только с указанием автора (Михаил Русаков) и индексируемой прямой ссылкой на сайт (http://myrusakov.ru)!

Добавляйтесь ко мне в друзья ВКонтакте: http://vk.com/myrusakov.
Если Вы хотите дать оценку мне и моей работе, то напишите её в моей группе: http://vk.com/rusakovmy.

Если Вы не хотите пропустить новые материалы на сайте,
то Вы можете подписаться на обновления: Подписаться на обновления

Если у Вас остались какие-либо вопросы, либо у Вас есть желание высказаться по поводу этой статьи, то Вы можете оставить свой комментарий внизу страницы.

Порекомендуйте эту статью друзьям:

Если Вам понравился сайт, то разместите ссылку на него (у себя на сайте, на форуме, в контакте):

  1. Кнопка:

    Она выглядит вот так: Как создать свой сайт

  2. Текстовая ссылка:

    Она выглядит вот так: Как создать свой сайт

  3. BB-код ссылки для форумов (например, можете поставить её в подписи):

Комментарии (1):

akhmed51 akhmed51 02.02.2025 13:18:51

Спасибо Михаил! Ваши уроки очень полезные и необходимые для обучения! С уважением к Вам Ахмад Гапурович

Ответить

Для добавления комментариев надо войти в систему.
Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.