Вчера у меня была похожая проблема, и я нашел решение, позволяющее различать старые и новые значения ввода текста.
Вывод выглядит так:
Старое значение: тестовый тест
Новое значение: тест с
Изменение: переписал 'test' с 'w' в позиции 5
Сценарий использует window.setInterval (), чтобы избежать кросс-браузерных проблем (см. https://stackoverflow.com/a/1949416/727190).). Это приводит к пакетированию некоторых изменений, когда пользователь набирает очень быстро - это может быть хорошо, зависит от вашей ситуации.
Однако вы можете легко изменить сценарий для обработки событий.
http://jsfiddle.net/6zp48/2/
Выдержка из скрипта, показывающая результат diff (код findChange () слишком длинный для вставки):
var changeType = { added: 0, deleted: 1, overwrite: 2 };
var previousValue = '';
window.setInterval(checkChange, 100);
function checkChange() {
var newValue = $("#input1").val();
if(newValue != previousValue) {
showChange(findChange(previousValue, newValue));
previousValue = newValue;
}
}
function showChange(result) {
$("#last-change").html("Prev: " + previousValue + "<br/>Next:" + $("#input1").val() + "<br/>");
if(result == null) {
$("#last-change").html($("#last-change").html() + " no change detected");
return;
}
switch (result.change) {
case changeType.added:
$("#last-change").html($("#last-change").html() + "added '" + result.added.text + "' at position " + result.added.position + "<br />");
break;
case changeType.deleted:
$("#last-change").html($("#last-change").html() + "deleted '" + result.lost.text + "' at position " + result.lost.position + "<br />");
break;
case changeType.overwrite:
$("#last-change").html($("#last-change").html() + "overwrote '" + result.lost.text + "' with '" + result.added.text + "' at position " + result.added.position + "<br />");
break;
}
}