Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.84/25: Рейтинг темы: голосов - 25, средняя оценка - 4.84
 Аватар для kupidon
0 / 0 / 2
Регистрация: 21.02.2013
Сообщений: 118

Получить значения INPUT до и после внесения изменений и сравнить их

04.11.2016, 20:18. Показов 4975. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день.
На странице есть INPUT. задача такая: если изменения в инпут произошли - то alert('есть изменения')
Вот как полагал сделать. Страница загрузилась, считываем значение инпута и присвоиваем глоб переменной. Потом при изменении инпута сравниваем новое значение инпута и старое и делаем оповещение, были ли изменения или нет.


(Или такое сравнение не надо делать при ONCHANGE?)

HTML5
1
<input size="100" onchange="set_purchase_name(1754,'name');" id="purchase_name" value="&quot;NOVA&quot; тестовая закупка " autocomplete="off" type="text">
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
jQuery(document).ready(function ($){
var pur_name_old = document.getElementById("purchase_name").value;
}); 
 
function set_purchase_name($id,$field){
var pur_name_new = document.getElementById("purchase_name").value;
alert(pur_name_new);
if (pur_name_old <> pur_name_new) {
    alert("Есть изменения");
    } else {
    alert("Изменений не было");    
    }
}
Еще ответьте пожалуйста: почему когда я заменяю:
var pur_name_new = document.getElementById("purchase_name").value;
на
var pur_name_new = $("#purchase_name").value;
перестает работать (( Что не так?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.11.2016, 20:18
Ответы с готовыми решениями:

На сайте не видно изменений после их внесения!
Здравствуйте. На сайте был установлен плагин Hyper Cache. Удалил его. Теперь на сайте вношу изменений, а они не отображаются на сайте... ...

Обновление базы после внесения изменений
Понимаю, что нубский вопрос, но даже не знаю как правильно загуглить. В 1С почти не шарю, но посадили дописывать конфигурацию. Есть уже...

Восстановление данных после внесения изменений в реестр
Здравствуйте, коллеги! Большая проблема. На компьютере под управлением Windows 7 внес изменения в реестре: после какой-то фигни создалась...

6
 Аватар для vettel
84 / 84 / 41
Регистрация: 14.02.2015
Сообщений: 320
04.11.2016, 20:33
kupidon,
JavaScript
1
if (pur_name_old <> pur_name_new)
<> - это что за оператор такой? Проверка на неравенство делается через !==.

Цитата Сообщение от kupidon Посмотреть сообщение
Еще ответьте пожалуйста: почему когда я заменяю:
var pur_name_new = document.getElementById("purchase_name") .value;
на
var pur_name_new = $("#purchase_name").value;
перестает работать (( Что не так?
"Не так" состоит в том, что не нужно путать jQuery и JS. У объекта jQ нет свойства value, оно есть только у DOM-объекта (на чистом js).
Чтобы считать значение поля на jQuery, нужно юзать методы jQuery.
JavaScript
1
var pur_name_new = $("#purchase_name").val()
1
 Аватар для kupidon
0 / 0 / 2
Регистрация: 21.02.2013
Сообщений: 118
04.11.2016, 20:49  [ТС]
Спасибо за помощь, исправил.
по поводу знака неравенства тоже были сомнения. исправил. Но сравнения не происходит все равно. Первая переменная не видна:
pur_name_old is not defined
0
 Аватар для vettel
84 / 84 / 41
Регистрация: 14.02.2015
Сообщений: 320
04.11.2016, 20:53
Цитата Сообщение от kupidon Посмотреть сообщение
Первая переменная не видна:
Область видимости. У вас переменную видно только в блоке между 1-ой и третьей строкой.
Засуньте вашу ф-ю setPurchaseName внутрь document-ready.
1
 Аватар для kupidon
0 / 0 / 2
Регистрация: 21.02.2013
Сообщений: 118
04.11.2016, 20:57  [ТС]
пробовал...
в таком случае функция вообще перестает срабатывать. ((
0
 Аватар для vettel
84 / 84 / 41
Регистрация: 14.02.2015
Сообщений: 320
04.11.2016, 21:02
Лучший ответ Сообщение было отмечено kupidon как решение

Решение

kupidon, ну да. Ф-я опять же будет видима лишь в пределах блока.
Вы в первом посте писали про глобальную переменную, но по сути она у вас локальная. Сделайте ее глобальной. Для этого она должна быть вынесена вне всех ф-ий. Можно конечно и явно сделать ее глобальной window.our_name_old, но лучше не стоит.
Вот так должно работать:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
var pur_name_old;//выносим переменную в глобальную область видимости
jQuery(document).ready(function ($){
pur_name_old = document.getElementById("purchase_name").value; //меняем значение глобальной переменной
}); 
 
function set_purchase_name($id,$field){
var pur_name_new = document.getElementById("purchase_name").value;
alert(pur_name_new);
if (pur_name_old !== pur_name_new) { //здесь все должно быть видно
    alert("Есть изменения");
    } else {
    alert("Изменений не было");    
    }
}
1
 Аватар для kupidon
0 / 0 / 2
Регистрация: 21.02.2013
Сообщений: 118
04.11.2016, 21:09  [ТС]
Спасибо огромное , все получилось!!!!!!!!!!!!1
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
var pur_name_old;//выносим переменную в глобальную область видимости
jQuery(document).ready(function ($){
var pur_name_old = document.getElementById("purchase_name").value;
}); 
 
function set_purchase_name($id,$field){
var pur_name_new = document.getElementById("purchase_name").value;
if (pur_name_old !== pur_name_new) {
    alert("Отличаются значения");
    } else {
    alert("Изменений не было");    
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.11.2016, 21:09
Помогаю со студенческими работами здесь

После внесения изменений в код проект уже не компилируется
Здравствуйте, может кто-нибудь сталкивался с такой проблемой: Захожу в студию пишу проект(без разницы причём какой допустим сейчас asp. net...

После внесения изменений в раздел permissions в проекте появились ошибки
Доброго времени суток! Компилировал проект в Debug(Rad10) режиме на реальное устройство, тестил, всё было хорошо. Далее мне потребовалось...

Обновление существующегося сайта (после внесения каких-либо изменений в логику и классы)
Добрый день. Хотелось бы узнать как правильно обновлять сайт который работает и залит на хостинг, если были внесены какие то изменения в...

Visual Studio: даже после внесения изменений в код запускается последняя успешно скомпилированная версия
Не знаю как получилось, но в определённом проекте вношу изменения в код и запускается последняя успешно скомпилированная версия кода. ...

Изменение значения в ячейки после внесения изменения в поле
Добрый день, уважаемые форумчане. Продолжаю разбираться с макросами. Появилась необходимость расчета формулы в ячейке, одним из параметров...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru