<MyRusakov.ru />

Профессия Web-разработчик

Профессия Web-разработчик

Этот комплект за 8 месяцев превратит Вас в Web-разработчика с нуля. Учиться достаточно 1 час в день.

Начнёте Вы с HTML, CSS и вёрстки сайтов. Потом перейдёте к программированию и JavaScript. Затем изучите PHP, MySQL, SQL, Python. Изучите Web-фреймворки Laravel и Django. Создадите 5 своих сайтов для портфолио.

Комплект содержит:

- 540 видеоуроков

- 110 часов видео

- 1205 заданий для закрепления материала из уроков

- 5 финальных тестов

- 7 сертификатов

- 12 Бонусных курсов

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

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

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

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

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

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

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

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

Как сохранить данные из HTML contenteditable на сервере в PHP?

Как сохранить данные из HTML contenteditable на сервере в PHP?

Доброго времени суток!

В данной статье мы рассмотрим с Вами один из способов отправки на сервер содержимого div блока с атрибутом contenteditable.

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

А теперь рассмотрим как можно это реализовать. Код ниже представляет базовую форму для добавления статьи на сайте.


<form action="/post" method="post">

    <h3 class="pb-3">Новая статья</h3>

    <div class="mb-3">
        <label for="newsTitle" class="form-label">Заголовок</label>
        <input type="text" class="form-control" id="newsTitle" name="title" value="" placeholder="Type title here">
    </div>

    <div class="mb-3">
        <label for="formatted_input" class="form-label">Текст</label>

        <!-- Наш блок с редактируемым текстом  -->
        <div id="formatted_input" contenteditable style="border:solid 1px gray;padding:1em;width:100%;min-height:2em;"></div>

        <!-- Скрытое поле, которое будет содержать текст из блока выше -->
        <input type="hidden" name="content" value="" id="formatted_input_value"/>
    </div>

    <div class="mb-3">
        <input type="submit" value="Добавить" class="btn btn-success" name="postSubmit"/>
    </div>

</form>

<script>

    document.addEventListener('DOMContentLoaded', () => {
        const editor = document.querySelector('#formatted_input');
        const post_content = document.querySelector('#formatted_input_value');

        // когда редактируется блок, его содержимое попадает в скрытое поле
        editor.addEventListener('input', () => {
            post_content.value = editor.innerHTML.trim();
        });
    });
</script>

Таким образом, текст из блока contenteditable попадает в скрытое поле, которое при отправке формы обычным образом отправляется на сервер.

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

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

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

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

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

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

  1. Кнопка:

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

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

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

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

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

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