Javascript-форум (https://javascript.ru/forum/)
-   Javascript под браузер (https://javascript.ru/forum/css-html/)
-   -   Функция Code View в визуальном редакторе (https://javascript.ru/forum/css-html/76319-funkciya-code-view-v-vizualnom-redaktore.html)

Katy93 28.12.2018 04:17

Функция 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 теги. Как можно это реализовать?

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

Nexus 28.12.2018 14:52

function getCode(){
    return iDoc.body.innerHTML;
}

console.log(getCode());

Katy93 28.12.2018 20:47

Спасибо, работает


Часовой пояс GMT +3, время: 01:42.