0

我无法在同一元素上成功使用来自 focusout 事件的 .focus() 。我也用 setTimeout 试过了。有任何想法吗?

    $(control).focusout(function (e) {
                    if ($(this).val().length > 0) {
                        for (var ii = 0; ii < sampleDTOList.length; ii++) {
                            if (sampleDTOList[ii]["controlId"] == $(this).attr("id")) {
                                if ($(this).val() <= parseFloat(sampleDTOList[ii]["maxValue"]) && $(this).val() >= parseFloat(sampleDTOList[ii]["minValue"])) {
                                    sampleDTOList[ii]["value"] = $(this).val();
                                    RunRulesOnSample(sampleDTOList[ii]);
                                    return;
                                }
                                else {
                                    $(this).val("");
                                    alert("You must enter a value between " + sampleDTOList[ii]["minValue"] + " and " + sampleDTOList[ii]["maxValue"] + ".");
                                    $(this).focus();
                                    return;
                                }
                            }
                        }
                    }
                });
4

1 回答 1

0

我认为不可能直接在 focusout 事件处理程序上调用 focus 函数。此外,您不能在事件对象上说 preventDefault(),因为 focusout 事件是不可取消的。

但似乎您可以使用 setTimeout 函数:

$('#foo').focusout(function(e) {
    setTimeout(function() {
        $('#foo').focus();
    }, 10);
});

看看这个jsFiddle

您还可以在此处找到使用该mousedown事件的解决方法

于 2013-06-19T23:28:42.920 回答