<MyRusakov.ru />

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Создание строки запроса из объекта в JavaScript

Создание строки запроса из объекта в JavaScript

Доброго времени суток! При создании веб-сайтов часто, если не всегда, приходится иметь дело с фильтрацией и сортировкой результатов запроса к базе данных. Эти операции осуществляются на основе данных пришедших в запросе на сервер из браузера, например.

А данные для фильтрации, это как правило, некоторый объект JavaScript, который описывает, какие данные нужны и как их сортировать.

Далле мы рассмотрим с Вами пример, того как можно преобразовать JavaScript объект в строку запроса (query string), которую потом можно будет передать на сервер в виде GET параметра.

Итак, для начала определим некоторые вспомогательные функции, необходимые для работы функции buildQueryString.

// Функция для проверки, является ли объект пустым
function isEmpty(obj) {
    // Проверяем, если длина массива ключей объекта равна 0, то объект пуст
    if (Object.keys(obj).length === 0) {
        return true;
    }

    // Проверяем каждое свойство объекта на пустоту
    for (const key in obj) {
        const value = obj[key];
        // Если значение не является пустым, объект не пуст
        if (
            value !== null &&
            value !== '' &&
            !(Array.isArray(value) && value.length === 0) &&
            !(typeof value === 'object' && isEmpty(value))
        ) {
            return false;
        }
    }

    // Если не найдены непустые свойства, объект пуст
    return true;
}

// Функция для удаления пустых полей из объекта
function removeEmptyFields(obj) {
    return Object.keys(obj).reduce((acc, key) => {
        const value = obj[key];
        // Если значение не пусто, добавляем его в аккумулятор
        if (value !== null && value !== '' && !(Array.isArray(value) && value.length === 0)) {
            acc[key] = value;
        }
        return acc;
    }, {});
}

// Функция для построения строки запроса из объекта параметров
function buildQueryString(params = {}, parentKey = null) {
    const queryString = [];

    // Проверяем, если объект параметров пуст, возвращаем undefined
    if (isEmpty(params)) return;

    // Обходим каждое свойство объекта параметров
    for (const key in params) {
        if (params.hasOwnProperty(key)) {
            const value = params[key];

            // Строим ключ с учетом вложенности
            const constructedKey = parentKey ? `${parentKey}[${key}]` : key;

            // Если значение является объектом и не пусто, обрабатываем его
            if (typeof value === 'object' && Object.entries(value).length !== 0) {
                // Удаляем пустые поля из объекта и рекурсивно строим строку запроса для вложенных объектов
                const _value = removeEmptyFields(value);
                queryString.push(buildQueryString(_value, constructedKey));
            } else {
                // Если значение существует, добавляем его в строку запроса с кодированием URI
                if (value) {
                    queryString.push(`${constructedKey}=${encodeURIComponent(value)}`);
                }
            }
        }
    }

    // Фильтруем undefined элементы и пустые строки, объединяем элементы в строку запроса с символом &
    return queryString.filter(v => v !== undefined).filter(s => s?.trim().length !== 0).join('&');
}

Тестируем на следующих данных:

const testData = 
{
    "filters": {
        "customer_id": null,
        "couriers": [],
        "order_statuses": [
            6,
            5,
            3,
            1,
            7,
            8,
            4
        ],
        "addresses_from": [],
        "addresses_to": [],
        "start_datetime": "",
        "end_datetime": "",
        "customer_cities": [
            1,
            2,
            8
        ]
    },
    "sort": {
        "customer": "asc"
    }
}


const query_string = buildQueryString(testData);

// Получем следующую строку, которую можно отправлять на сервер

// filters[order_statuses][0]=6&filters[order_statuses][1]=5&filters[order_statuses][2]=3&filters[order_statuses][3]=1&filters[order_statuses][4]=7&filters[order_statuses][5]=8&filters[order_statuses][6]=4&filters[customer_cities][0]=1&filters[customer_cities][1]=2&filters[customer_cities][2]=8&sort[customer]=asc

const url = 'https://srs.myruakov.ru' + '?' + query_string;
console.log(url);

Таким образом, объект, который мы передаем в функция buildQueryString может состоять из необходимых для фильтрации и сортировки параметров. Однако, имейте ввиду, что не стоит делать строку запроса (query_string) слишком длинной (можно сделать имена свойств короче в объекте testData), а также, все данные, пришедшие на сервер необходимо обязательно проверять, на соответствие правилам безопасности.

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

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

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

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

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

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

  1. Кнопка:

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

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

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

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

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

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