在IE中的占位符上触发的jQuery输入事件

时间:2013-10-10 07:16:43

标签: jquery html internet-explorer input placeholder

我有一个绑定了input事件的输入字段(通过jQuery)。每次输入值更改时都应触发此事件。我添加了一个占位符来告诉用户此输入字段的用途。

如果用户点击此输入字段,则不应触发input事件(该值实际上不会更改;只是占位符消失)。它适用于Firefox或Chrome,但不适用于IE。

我该如何避免这种行为?

为了更好地理解我在jsfiddler

上的问题

2 个答案:

答案 0 :(得分:1)

防范此问题的一种方法是在执行要在input处理程序中执行的实际功能之前,存储字段的旧值并进行检查。这就是我在其中一个应用程序中修复它的方法。

例如:

$(document).ready(function () {
    var $input = $("#input");
    var $msg = $("#msg");
    var old_value = $input.val();
    $input.on("input", function () {
        var new_value = $input.val();
        if (new_value !== old_value) {
            // The actual work we want to perform when the field *really* changes.
            $msg.text(new_value.length);
            old_value = new_value;
        }
    });
});

这可以防止在字段未更改时进行操作。

答案 1 :(得分:-1)

尝试将此添加到输入事件:

if($(this).val() == $(this).get(0).defaultValue) return;