У меня есть один пример валидатора формы в java-скрипте. В этом случае, есть ли способ проверить, грязная ли форма или нет?
Моя платформа - JavaScript
Найдите соответствующий образец ниже и предложите любое решение.
фрагмент кода: я использовал как:
if (name.value != name.defaultValue) {
alert("#name has changed");
}Я хочу проверить, грязная ли форма. если форма грязная, должно появиться всплывающее окно. есть ли способ проверить это в javascript.
@SumeshTG, в angular у них есть грязная переменная, которая показывает, грязная форма или нет. но я хочу проверить это в javascript
Что вы имеете в виду, когда говорите «грязный»?
если какой-либо элемент формы был затронут или изменен, то форма грязная
@PoulBak, проверьте эту ссылку w3schools.com/angular/angular_validation.asp
Используйте валидатор jquery.
@SumeshTG, как я могу это сделать
@kumaresan_sd Обратитесь к jqueryvalidation.org/documentation. Поделитесь своей формой поможет вам реализовать
@SumeshTG, проверьте этот образец. мне это нужно. если вы измените ввод, и они отправят его, покажут какое-то сообщение, которое показывает грязный stackblitz.com/edit/m4tbav-d5xcfq?file=index.js
Пожалуйста, включите свой фрагмент кода



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Вы можете использовать JQuery примерно так ...
var _isDirty = false;
$("input[type='text']").change(function(){
_isDirty = true;
});
не могли бы вы предоставить образец на основе этого?
Вам нужна глобальная логическая переменная, которую нужно помнить, когда вы редактируете что-либо в вашей форме.
Эта переменная изначально должна иметь значение false, затем, когда пользователь редактирует ввод, она изменяется на true. Когда вы отправляете форму, она снова становится false. Теперь вы можете в любое время проверить, является ли грязная переменная истинной или ложной.
Пример кода:
var dirty = false;
var inputs = document.querySelectorAll('input');
for (var i = 0;i < inputs.length)
{
var input = inputs[i];
input .addEventListener('input', function()
{
dirty = true;
});
}
var form = document.forms[0];
form.addEventListener('submit, function()
{
dirty = false;
}
у вас есть такие теги, как kendo-ui-grid и kendo-validator, поэтому я полагаю, вы используете структуру kendo. если вы хотите увидеть, не загрязнена ли форма, вы должны проверить viewModel в кендо способом образец.
в основном я создал viewModel, который реализует интерфейс ObservableObject и имеет двустороннюю привязку к контейнеру формы. Каждый раз, когда вы что-то меняете в форме, в viewModel запускается событие изменения, которое устанавливает для переменной (dirty) значение true.
var dirty = false;
var viewModel = new kendo.data.ObservableObject({
fullname: "test"
});
viewModel.bind("change", function () {
alert("changed");
dirty = true;
});
kendo.bind($("#tickets"), viewModel);
Добавьте все поля, которые вам нужно «наблюдать» в ObservableObject.
и установите на их разметке свойство data-bind = "value:fieldName"
Спасибо, но я не хотел этого ответа, я уже проверял эту концепцию
С какой проблемой вы столкнулись