Привет,
Подскажите, пожалуйста, как можно получить элементы DOM в Discourse, не прибегая к использованию setTimeout и querySelector?
Сейчас я делаю примерно так:
setTimeout(() => {
var createTopicButton = document.querySelector("#create-topic");
if(createTopicButton)
createTopicButton.onclick = function (e) {
if (window.Moengage && window.Moengage.track_event) {
window.Moengage.track_event("Topic_Create_Clicked", {});
}
setTimeout(() => {
var topicCreate = document.querySelector("#reply-control .save-or-cancel .btn-primary")
topicCreate.onclick = function (e) {
let heading = document.querySelector('#reply-control #reply-title').value;
let category = document.querySelector('.select-kit-header-wrapper>.select-kit-selected-name>.name>.badge-wrapper>.badge-category>.category-name')?.innerText;
let desc = document.querySelector('.d-editor-textarea-column>.d-editor-textarea-wrapper>textarea').value;
let imagePresent = desc.includes("upload://");
if (window.Moengage && window.Moengage.track_event && heading && category && desc) {
window.Moengage.track_event("Topic_Created", {"Category":category,"Topic Name":heading,"Topic Description":desc,"Is_image_present":imagePresent});
}
}
},[300])
};
},[500])
Если не использовать указанные выше таймауты, то иногда элементы DOM возвращаются как null, поскольку DOM ещё не полностью загрузился, даже если код обернут в функцию window.onload.
Моя цель — получать элементы DOM и изменять их обработчики событий onChange.
Буду очень признателен за любую помощь.
Спасибо ![]()