我想捕捉如果发生了任何变化<textarea>。比如输入任何字符(删除,退格)或鼠标点击粘贴或剪切。是否有一个jQuery事件可以触发所有这些事件?
我尝试了更改事件,但它只在从组件tab out后触发回调。
使用:我想启用一个按钮,如果<textarea>包含任何文本。
我想捕捉如果发生了任何变化<textarea>。比如输入任何字符(删除,退格)或鼠标点击粘贴或剪切。是否有一个jQuery事件可以触发所有这些事件?
我尝试了更改事件,但它只在从组件tab out后触发回调。
使用:我想启用一个按钮,如果<textarea>包含任何文本。
当前回答
试试这个
$('textarea').trigger('change');
$("textarea").bind('cut paste', function(e) { });
其他回答
.delegate是唯一一个工作到我与jQuery JavaScript库v2.1.1
$(document).delegate('#textareaID','change', function() {
console.log("change!");
});
试着集中精力做这件事
$("textarea").focusout(function() {
alert('textarea focusout');
});
使用输入事件。
var button = $("#buttonId");
$("#textareaID").on('input',function(e){
if(e.target.value === ''){
// Textarea has no value
button.hide();
} else {
// Textarea has a value
button.show();
}
});
试试这个吧:
$('#textareaID').bind('input propertychange', function() {
$("#yourBtnID").hide();
if(this.value.length){
$("#yourBtnID").show();
}
});
DEMO
这适用于你所做的任何更改,输入,剪切,粘贴。
经过一些实验,我想出了这个实现:
$('.detect-change')
.on('change cut paste', function(e) {
console.log("Change detected.");
contentModified = true;
})
.keypress(function(e) {
if (e.which !== 0 && e.altKey == false && e.ctrlKey == false && e.metaKey == false) {
console.log("Change detected.");
contentModified = true;
}
});
处理对任何类型的输入和选择的更改,以及忽略方向键和ctrl, cmd,功能键等的文本区域。
注意:我只在FF中尝试过,因为这是一个FF插件。