Форум программистов, компьютерный форум, киберфорум
JavaScript для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
97 / 11 / 1
Регистрация: 14.03.2017
Сообщений: 196

Небольшой текстовый редактор

22.06.2019, 16:51. Показов 2077. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Мне нужно на своем локальном сайте получить примерно то, что есть на каждом форуме - вот этот вот текстовый редактор.
То есть, чтобы при нажатии на кнопку выделенный текст обрамлялся тегами. Я искал в инете инфу и там все ответы приводились к использования Range. Однако все эти примеры не работают. Приведу код:

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
var t = document.getElementById('textEditor');
 
function insertText(text) {
  //ищем элемент по id
    var txtarea = t;
    //ищем первое положение выделенного символа
    var start = txtarea.selectionStart;
    //ищем последнее положение выделенного символа
    var end = txtarea.selectionEnd;
    // текст до + вставка + текст после (если этот код не работает, значит у вас несколько id)
    var finText = txtarea.value.substring(0, start) + text + txtarea.value.substring(end);
    alert(finText);
    // подмена значения
    txtarea.value = 'b';
    alert(txtarea.value);
    // возвращаем фокус на элемент
    txtarea.focus();
    // возвращаем курсор на место - учитываем выделили ли текст или просто курсор поставили
    txtarea.selectionEnd = ( start == end )? (end + text.length) : end ;
}
Так вот, ни fintext, не txtarea.value в себе ничего не содержат. В функцию заходит, проверял.
Как можно получить значение textarea и правильная вообще функция или нет?:

P.S. и да, textEditor один.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
22.06.2019, 16:51
Ответы с готовыми решениями:

Текстовый редактор
Нужен текстовый редактор, хотя бы самый простенький. Но раньше с его установкой на сайт, никогда не работал... Подскажите: 1) Где его...

Текстовый редактор на JavaScript
Всем доброго времени суток. Помогите пожалуйста решить задачку. Мне понадобился простенький текстовый редактор для сайта. С помощью гугла...

Текстовый редактор на сайте(кнопки).
Как сделать такое: например, в textarea ввожу текст, и скажем часть текста нужно сделать жирным...например я выделил мышью нужный текст и...

5
39 / 22 / 10
Регистрация: 31.05.2017
Сообщений: 152
22.06.2019, 19:44
Diochrome, попробуйте посмотреть что-то на подобии https://bootstrap-wysiwyg.gith... 3-wysiwyg/
или http://suyati.github.io/line-control/ лёгкие довольно редакторы
0
97 / 11 / 1
Регистрация: 14.03.2017
Сообщений: 196
22.06.2019, 19:58  [ТС]
Спасибо. Лучше, конечно, понять, почему не работает этот код, ну да ладно. Пойду копаться в чужом коде.
0
39 / 22 / 10
Регистрация: 31.05.2017
Сообщений: 152
22.06.2019, 20:50
Diochrome, вы пытаетесь велосипед изобретать, если уж есть готовые решения, то почему бы не подчеркнуть с них идею. Кроме того можете посмотреть как реализованы эти редакторы и реализовать то же самое, но под себя.
0
Эксперт JS
2037 / 1096 / 409
Регистрация: 29.04.2016
Сообщений: 2,625
23.06.2019, 02:12
Лучший ответ Сообщение было отмечено Diochrome как решение

Решение

Цитата Сообщение от Diochrome Посмотреть сообщение
ну да ладно


Ваш код рабочий... и если его немного переделать -> https://codepen.io/Mr_Sergo/pe... itors=1010 то будет то что вам нужно

HTML5
1
2
3
4
5
6
7
<br>
<input class="add_text" type="button" value="BOLD">
<input class="add_text" type="button" value="ITALIC">
<input class="add_text" type="button" value="UNDERLINE">
<br><br>
 
<textarea id="area" rows="10" cols="100">Поле `textarea` представляет собой элемент формы для создания области, в которую можно вводить несколько строк текста. В отличие от тега `input` в текстовом поле допустимо делать переносы строк, они сохраняются при отправке данных на сервер.</textarea>
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
const insertText = (el,tag) => {
    let txtarea = document.querySelector(el),
        start = txtarea.selectionStart,
        end = txtarea.selectionEnd,
        sel = txtarea.value.substring(start, end),
        finText = (txtarea.value.substring(0, start) + tag[0]) + sel + (tag[1] + txtarea.value.substring(end))
    ;
    txtarea.value = finText;
    txtarea.focus();
}
 
let button = document.querySelectorAll('.add_text');
 
button[0].addEventListener('click',() => insertText('#area',['[BOLD]','[/BOLD]']) );
button[1].addEventListener('click',() => insertText('#area',['[ITALIC]','[/ITALIC]']) );
button[2].addEventListener('click',() => insertText('#area',['[UNDERLINE]','[/UNDERLINE]']) );
1
 Аватар для atanov
640 / 481 / 172
Регистрация: 26.05.2016
Сообщений: 2,674
23.06.2019, 08:04
Diochrome, я Вам страшную тайну открою - если Вы сделаете редактируемые div вместо инпута, то текст введённый и выделенный в таком диве можно сделать жирным с помощью ctrl+B, италиком ctrl+I, ну а подчёркнутым - сами догадайтесь
А если и кнопички нужны, то есть малоиспользуемый, но отличный метод execCommand.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
23.06.2019, 08:04
Помогаю со студенческими работами здесь

Текстовый редактор кода с нуля
Помогите советами! Хочу начать писать СВОЙ текстовый редактор кода под броузер. (под особый узкоспециализированный скриптовый язык) ...

текстовый редактор, заменить div на p
Здравствуйте. Пишу текстовый редактор для админки, есть такая проблема : в окне редактора (iframe с designMode = &quot;on&quot;) , по...

Небольшой редактор страничек
&lt;?php include_once('config.php'); ?&gt; &lt;html&gt; &lt;body&gt; &lt;table border=&quot;1&quot; align=&quot;center&quot;&gt; &lt;? $sql = mysql_query(&quot;SELECT * FROM...

Текстовый редактор
подскажите, как создать текстовое поле на C++ для текстового редактора среда netbeans у меня есть минимальное приложение...

Текстовый редактор
Доброго времени суток! На работе возникла необходимость внедрить на страницу текстовый редактор. Ранее пользовался Tinymce, но немного не...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru