TinyMCE с ReactJs — событие onChange срабатывает только один раз

Я использую tinyMCE с моим приложением reactjs. Событие onChange сработает один раз, правильно отражая входные данные в предупреждении. Тогда я ничего не получу.

Вот соответствующий код:

<Editor init = {{
    statusbar: false,
    menubar: false,
    }}
    onChange = {this.SetText}
 />

Метод onChange:

SetText(e) {
    alert(e.target.getContent());
}
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
2
0
2 170
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Может быть, одно из этих событий проходит лучше, чем onChange?

  • KeyDown — срабатывает при нажатии клавиши в редакторе.
  • KeyPress — срабатывает при нажатии клавиши в редакторе.
  • KeyUp — срабатывает при отпускании клавиши в редакторе.

https://www.tiny.cloud/docs/advanced/events/

Что ж, я думаю, что при изменении состояния я должен придерживаться нативных событий reactjs, не так ли? В любом случае я могу играть с ними, потому что сейчас я в растерянности.

silencedogood 08.04.2019 15:30

Я думаю, что вы можете изменить состояние с помощью событий tinyMCE. Но вы должны связать свою функцию в конструкторе (или использовать функцию массива), чтобы получить контекст компонента в методе события.

Uladzislau Ulasenka 08.04.2019 15:34

Да. Что ж, через некоторое время попробую. Если это окажется жизнеспособным, и никто не сможет ответить, почему onChange срабатывает только один раз, я отмечу вас для решения. Спасибо

silencedogood 08.04.2019 15:51
Ответ принят как подходящий

На самом деле событие, которое вы используете, неверно. Для плагина reactJs у них есть onEditorChange. Вы можете использовать его следующим образом

<Editor
  apiKey = "MyAPIKey"
  initialValue = ""
  init = {{
    height: 500,
    menubar: false,
    plugins: [
      'advlist autolink lists link image charmap print preview anchor',
      'searchreplace visualblocks code fullscreen',
      'insertdatetime media table paste code help wordcount'
    ],
    toolbar:
      'undo redo | formatselect | bold italic backcolor | \
      alignleft aligncenter alignright alignjustify | \
      bullist numlist outdent indent | removeformat | help'
  }}
  onEditorChange = {this.onChange}
/>

а затем вы можете получить доступ к содержимому редактора, используя

  onChange = (content) => {
    console.info(content);
  }

e.target не требуется

В итоге я обратился к другому редактору, но только сейчас понял, что вы дали правильный ответ. Спасибо

silencedogood 17.06.2021 15:17

Другие вопросы по теме