Показать сообщение отдельно
  #1 (permalink)  
Старый 28.12.2018, 04:17
Кандидат Javascript-наук
Отправить личное сообщение для Katy93 Посмотреть профиль Найти все сообщения от Katy93
 
Регистрация: 28.12.2018
Сообщений: 138

Функция Code View в визуальном редакторе
Не давно решила сделать простенький визуальный редактор. Стала искать информацию в интернете. И нашла вот пример:
<html>
<head></head>
<body>
<form name="myform" action="#" method="post" onsubmit="return save()">
  <p>
    <input type="hidden" id="content" name="content" value="" />
  </p>
  <script type="text/javascript">
    // Вывод кнопок редактирования
    document.write("<input type='button' value='B' onclick='setBold()' />");
    document.write("<input type='button' value='I' onclick='setItal()' />");
    document.write("<br />");
    document.write("<iframe scrolling='no' frameborder='no' src='#' id='frameId' name='frameId'></iframe>"); // Добавляем iframe
    /* В зависимости от браузера получаем доступ к созданному фрейму */
    var isGecko = navigator.userAgent.toLowerCase().indexOf("gecko") != -1;
    var iframe = (isGecko) ? document.getElementById("frameId") : frames["frameId"];
    var iWin = (isGecko) ? iframe.contentWindow : iframe.window;
    var iDoc = (isGecko) ? iframe.contentDocument : iframe.document;
    /* Создаём код пустой HTML-страницы */
    iHTML = "<html><head></head><body style='background-color: yellow;'></body></html>";
    iDoc.open(); // Открываем фрейм
    iDoc.write(iHTML); // Добавляем написанный код в фрейм
    iDoc.close(); // Закрываем фрейм
    iDoc.designMode = "on"; // Включаем режим редактирования фрейма
    /* Функции для задания внешнего вида выделенного текста
    Полный набор возможных команд: http://javascript.itsoft.ru/execcom/execCommands.html */
    function setBold() {
      iWin.focus();
      iWin.document.execCommand("bold", null, "");
    }
    function setItal() {
      iWin.focus();
      iWin.document.execCommand("italic", null, "");
    }
    function save() {
      /* Сохранение HTML-кода в поле hidden, чтобы потом можно было передать полученный HTML-код в скрипт-обработчик */
      document.getElementById("content").value = iDoc.body.innerHTML; 
      return true;
    }
  </script>
  <p>
    <input type="submit" value="Отправить" />
  </p>
</form>
</body>

В некоторых крутых визуальных редакторов есть такая функция View Code. Это когда при нажатии кнопки форматирование текста превращается в html теги. Как можно это реализовать?

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