Есть ли способ проверить, грязная ли форма или нет в JavaScript?

У меня есть один пример валидатора формы в java-скрипте. В этом случае, есть ли способ проверить, грязная ли форма или нет?

Моя платформа - JavaScript

Найдите соответствующий образец ниже и предложите любое решение.

образец ссылки

фрагмент кода: я использовал как:

if (name.value != name.defaultValue) { 
    alert("#name has changed"); 
    }

С какой проблемой вы столкнулись

Sumesh TG 18.10.2018 13:43

Я хочу проверить, грязная ли форма. если форма грязная, должно появиться всплывающее окно. есть ли способ проверить это в javascript.

Kumaresan Sd 18.10.2018 13:46

@SumeshTG, в angular у них есть грязная переменная, которая показывает, грязная форма или нет. но я хочу проверить это в javascript

Kumaresan Sd 18.10.2018 13:48

Что вы имеете в виду, когда говорите «грязный»?

Poul Bak 18.10.2018 14:04

если какой-либо элемент формы был затронут или изменен, то форма грязная

Kumaresan Sd 18.10.2018 14:10

@PoulBak, проверьте эту ссылку w3schools.com/angular/angular_validation.asp

Kumaresan Sd 18.10.2018 14:11

Используйте валидатор jquery.

Sumesh TG 18.10.2018 14:21

@SumeshTG, как я могу это сделать

Kumaresan Sd 18.10.2018 14:25

@kumaresan_sd Обратитесь к jqueryvalidation.org/documentation. Поделитесь своей формой поможет вам реализовать

Sumesh TG 18.10.2018 14:28

@SumeshTG, проверьте этот образец. мне это нужно. если вы измените ввод, и они отправят его, покажут какое-то сообщение, которое показывает грязный stackblitz.com/edit/m4tbav-d5xcfq?file=index.js

Kumaresan Sd 18.10.2018 14:32

Пожалуйста, включите свой фрагмент кода

Sumesh TG 18.10.2018 14:36
Поведение ключевого слова "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) для оценки ваших знаний,...
1
11
8 235
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

Вы можете использовать JQuery примерно так ...

var _isDirty = false;
$("input[type='text']").change(function(){
  _isDirty = true;
});

не могли бы вы предоставить образец на основе этого?

Kumaresan Sd 18.10.2018 13:47

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

Эта переменная изначально должна иметь значение 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"

Спасибо, но я не хотел этого ответа, я уже проверял эту концепцию

Kumaresan Sd 25.10.2018 13:44

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