Элемент DOM не обновлен в функции Handlers Event Handlers (SELECT/UNSELECT)Javascript

Форум по Javascript
Ответить Пред. темаСлед. тема
Anonymous
 Элемент DOM не обновлен в функции Handlers Event Handlers (SELECT/UNSELECT)

Сообщение Anonymous »

долго боролась с тегами Select2 Select2 (Valid/Invalid), как после невыполнения тега (SELECT2: UNSELECT EVENT) Состояние элемента DOM (выбрано JQUERY), не отраженное в функции обработчика.
Контекст:
У меня есть поле SELECT2 в моей форме, в котором нет параметров , доступных в раскрывающемся спине, так как вход обслуживает для создания новых объектов с тегами SELECT2: True Параметр.
на теге выбран Ajax < /code> GET запрос выполняется, чтобы проверить, существует ли такой объект. Если это так, то тег стиль, чтобы указать его неверное состояние. Он хорошо работает при добавлении новых тегов. Однако, если я не выберет даже один тег, остальные «неверные» теги восстанавливаются по умолчанию и все стили сбрасываются.
во время отладки я обнаружил, что при выборе2: Unselect < /code> обработчики (тег уже не выбран и удален из Dom Inpector в Браузер) Ссылки на контейнер родителей на детей, которые параметры не фактические в соответствии с dom (console.log () Печать детей, имеющих класс, который на самом деле не назначен в этот момент, но был назначен ранее Select2: Unselect событие).
let invalidTags = new Set();

function validateCustomTag() {
var tags = $("#serials-form").find("li.select2-selection__choice");

tags.each(function () {
const tag = $(this); // Get the current tag element
const serialNumber = tag.attr("title");

// Proceed with AJAX validation
$.ajax({
type: "GET",
url: SERIAL_NUMBER_VALIDATION_URL,
data: { serial_number: serialNumber },
dataType: "json",
success: function (data) {
const response = data.response;

if (!response.valid) {
// Add the invalid serial number to the Set
invalidTags.add(serialNumber);

// Append error message
const errorElement = `[*]${response.error}`;
$("#snAjaxErrors").removeClass("d-none");
$("#snAjaxErrors").append(errorElement);

}
},
});
});
}

function applyInvalidStyles() {
invalidTags.forEach((sn) => {
const select2FieldContainer = $("#serials-form")
let tag = select2FieldContainer.find(`li[title=${sn}]`)
tag.addClass("bg-danger bg-opacity-50 text-light");
});
}

$(document).ready(function () {
$("#id_serial_numbers").on("select2:select", function () {
validateCustomTag();
applyInvalidStyles();
});

$("#id_serial_numbers").on("select2:unselect", function () {
// Reapply invalid styles after any redraw
applyInvalidStyles();
});
)};


Подробнее здесь: https://stackoverflow.com/questions/793 ... t-function
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Элемент DOM не обновлен в функции Handlers Event Handlers (SELECT/UNSELECT)
    Anonymous » » в форуме Jquery
    0 Ответы
    14 Просмотры
    Последнее сообщение Anonymous
  • Trigger Custom Dom Event и потребление DOM Event, полученное в Java Eclipse RCP- jxbrowser
    Anonymous » » в форуме JAVA
    0 Ответы
    30 Просмотры
    Последнее сообщение Anonymous
  • Считается ли вызов функций манипуляции с DOM из модуля DOM.JS в модулях index.js как логика и разлука DOM?
    Anonymous » » в форуме Javascript
    0 Ответы
    22 Просмотры
    Последнее сообщение Anonymous
  • C# ListView ItemSelectionChanged Event Multi Select получает ТОЛЬКО последний выбранный элемент
    Anonymous » » в форуме C#
    0 Ответы
    18 Просмотры
    Последнее сообщение Anonymous
  • В чем разница между ожиданием Task Event и Event.Wait
    Anonymous » » в форуме C#
    0 Ответы
    43 Просмотры
    Последнее сообщение Anonymous

Вернуться в «Javascript»