Форум программистов, компьютерный форум, киберфорум
JavaScript для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 05.02.2019
Сообщений: 19

Contenteditable div, как менять тип элемента на котором находится курсор

26.06.2019, 16:41. Показов 1345. Ответов 6

Студворк — интернет-сервис помощи студентам
Здравствуйте, я сейчас делаю свой текстовой редактор или WYSIWYG, сделал кнопку которая добавляет заголовок второго уровня, но она не меняет обратно на обычный абзац, как это сделать?

HTML:
HTML5
1
2
3
4
5
6
7
<div>
<button class="bold">жирный</button>
<button class="italic">курсив</button>
<button class="header2">h2</button>
</div>
 
<div contenteditable id="editor-container"></div>
JavaScript:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
document.execCommand("defaultParagraphSeparator", false, "p");
 
$( '.bold' ).on( 'click', function() {
   document.execCommand( 'bold', null, null ); 
});
 
$( '.italic' ).on( 'click', function() {
   document.execCommand( 'italic', false, null ); 
});
 
$( '.header2' ).on( 'click', function() {
   document.execCommand( 'formatBlock', false, 'H2' ); 
});
Заранее спасибо
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.06.2019, 16:41
Ответы с готовыми решениями:

Сбивается курсор в div contenteditable
Здравствуйте! Подскажите, пожалуйста, как изменить текущий код так, чтобы курсор, установленный в div contenteditable, не сбивался, когда...

Как узнать id поля, в котором сейчас находится курсор?
У меня есть форма с полями input-text. Как узнать id поля, в котором сейчас находится курсор?

Запретить печатать в div с contenteditable за пределеами этого элемента
Привет всем, у меня возникла следующая задача: есть div с contenteditable, и у него указана ширина и высота. Проблема в том что когда текст...

6
68 / 60 / 10
Регистрация: 07.03.2019
Сообщений: 657
26.06.2019, 18:34
Не понимаю зачем для таких задач использовать execComand()????
Цитата Сообщение от Aleks00231 Посмотреть сообщение
но она не меняет обратно на обычный абзац
На что вы нажимаете , что пишет, мы же не должны гадать здесь.
0
0 / 0 / 0
Регистрация: 05.02.2019
Сообщений: 19
26.06.2019, 19:37  [ТС]
Добавлено через 4 минуты
Цитата Сообщение от server_net Посмотреть сообщение
На что вы нажимаете , что пишет, мы же не должны гадать здесь.
Я пишу абзац p, но потом его хочу изменить на заголовок h2, потом хочу изменить его опять на обычный абзац p, при этом нажимая одну и туже кнопку которая делает заголовок
0
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
26.06.2019, 22:08
Aleks00231,
Цитата Сообщение от Aleks00231 Посмотреть сообщение
Я пишу абзац p, но потом его хочу изменить на заголовок h2, потом хочу изменить его опять на обычный абзац p, при этом нажимая одну и туже кнопку которая делает заголовок


https://codepen.io/qwerty_wasd/pen/agLGyQ
HTML5
1
2
3
4
<div id="editor-container" contenteditable="true">пиши</div>
<button class="view bold">bold</button>
<button class="view italic">italic</button>
<button class="view bold">h2</button>
CSS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
.bold {
  font-weight: bold;
}
.italic {
  font-style: italic;
}
.h2 {
  display: block;
  font-size: 1.5em;
  margin-top: 0.83em;
  margin-bottom: 0.83em;
  margin-left: 0;
  margin-right: 0;
  font-weight: bold;
}
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
let opTextEd = {
  container: document.getElementById(`editor-container`),
  events: {
    click: evt => {
      if (evt.target.classList.contains(`view`)) {
        opTextEd.container.classList.toggle(evt.target.textContent);
      }
    },
  },
};
 
document.addEventListener(`click`, opTextEd.events.click);
0
74 / 29 / 4
Регистрация: 16.10.2017
Сообщений: 95
27.06.2019, 10:02
Qwerty_Wasd,
Это все не так буквально, эти редакторы подразумевают отправку на сервер текст с разметкой а не просто отображение, на более современном форуме через консоль видно что js добавляются убираются теги в разметке.
0
68 / 60 / 10
Регистрация: 07.03.2019
Сообщений: 657
27.06.2019, 14:34
timen, Вам нужно чтобы текст ваш форматировался и отправлялся в форматированном виде на сервер?
0
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
27.06.2019, 18:06
timen,
Цитата Сообщение от timen Посмотреть сообщение
эти редакторы подразумевают отправку на сервер текст с разметкой а не просто отображение
- ок

https://codepen.io/qwerty_wasd/pen/agLGyQ
HTML5
1
2
3
4
5
6
<div id="module-editable">
  <div id="editor-container" contenteditable="true">пиши</div>
  <button class="view bold">bold</button>
  <button class="view italic">italic</button>
  <button class="change-tag bold">h2</button>
</div>
CSS
1
2
3
4
5
6
.bold {
  font-weight: bold;
}
.italic {
  font-style: italic;
}
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
let opTextEd = {
  container: document.getElementById(`module-editable`),
  flag: true,
  events: {
    click: evt => {
      if (evt.target.classList.contains(`view`)) {
        opTextEd.container.firstElementChild.classList.toggle(evt.target.textContent);
      }
      if (evt.target.classList.contains(`change-tag`)) {
        let tag;
        [tag, evt.target.textContent]= [opTextEd.flag ? `h2` : `div`, !opTextEd.flag ? `h2` : `div`];
        opTextEd.container.firstElementChild.outerHTML = `<${tag} id="${opTextEd.container.id}" class="${opTextEd.container.firstElementChild.className}">${opTextEd.container.firstElementChild.innerHTML}</${tag}>`;
        opTextEd.flag = !opTextEd.flag;
        tag = undefined;
      }
    },
  },
};
 
document.addEventListener(`click`, opTextEd.events.click);
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.06.2019, 18:06
Помогаю со студенческими работами здесь

Получить имя элемента управления, на котором находится курсор
Доброго времени суток! Интересует такой вопрос: Подскажите пожалуйста, как получить имя элемента управления на котором находится сейчас...

Как отделить отдельный блок div со всем содержимым в нём html коде от всего кода, в котором этот div находится?
Здравствуйте. Есть много файлов html (70 штук) и в нём html код, такова плана: https://pastebin.com/LVSEx8em . Нужно автоматически отделить...

Установить курсор(фокус) в конец div contenteditable="true"
Искал, но не нашел нужного решения При нажатии на кнопку чтобы курсор был установлен в конце содержимого div элемента &lt;div...

Как получить id div-а, в котором находится кнопка?
доброе время суток, есть код: if($_SESSION == 'admin') { $f = '&lt;hr&gt;&lt;button type=&quot;submit&quot; name=&quot;edit&quot; class=&quot;btn btn-lg...

Определить текущий индекс, на котором находится курсор массива
var arr, , , ] for (var i = 0, L = inputArray.length; i &lt; L; i++) { for(var j=0; j&lt;L; j++) {//какие-то действия} Проходим по...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru