组合组件上的onBlur事件(输入+按钮)

时间:2015-05-27 13:37:58

标签: javascript html

我正在尝试创建一个由输入字段和按钮组成的“组合组件”。

我有以下jsfiddle作为示例:

http://jsfiddle.net/stt0waj0/

<div id="myComponent">
    <input type="text" onBlur="this.style.border='1px solid red';">
    <button type="button" onClick="alert('Hello World');">ClickMe</button>
</div>

我想要的行为是当我离开输入字段而不写任何内容时,我得到验证错误(在这种情况下为红色边框)。这已经在小提琴中起作用(内容验证不是问题的范围)。

但是,当我按下按钮离开输入字段时,我将打开一个对话框,允许选择输入字段的值,因此在这种情况下,我不希望验证运行。

所以,关于小提琴的具体问题:我可以单击输入字段,然后单击按钮而没有红色边框吗?但是,如果我单击输入字段,然后单击其他位置,我想要红色边框(任何onBlur除了单击按钮时)。

这可能没有肮脏的技巧吗?

我想避免的事情:

  • 在第一个事件上设置一个计时器以等待第二个事件(原因:性能)
  • 使onClick事件始终重置文本字段上的红色边框(原因:gui毛刺)

只是为了清楚我正在寻找什么以及为什么这个问题很有趣:onBlur事件在onClick事件之前被触发。但是,我通常需要onBlur知道onClick接下来,这是不可能的。这就是问题的关键所在。

想象一下日期选择器在空场上验证,当该字段具有焦点并按下日历时,即使您选择了日期,也会收到验证错误。我想知道是否有一种优雅的方式来处理这种情况。

1 个答案:

答案 0 :(得分:1)

要使其工作,如果用户按下按钮,您可以推迟验证功能。

下面是示例代码并小提示以显示我的意思。 *更新小提琴使用选择下拉菜单而不是按钮* Fiddle Demo

input.error {color: red; border: 1px solid red;}

<div id="myComponent">
<input id="btn" type="text" onBlur="inputBlur()">
<select type="button" data-btn="btn" onclick="inputButtonClick()" onchange="selectChange()" onblur="selectBlur()">
    <option value="">choose</option>
    <option value="item1">item1</option>
    <option value="item2">item2</option>
    <option value="item3">item3</option>
</select>
</div>

window.validate = function(input) {
    //do your validation
    var val;
    console.log("Validating");
    val = input.val();

    if ( !val || !val.length) {
        input.addClass("error");
        console.log("Something is invalid");
    } else {
        //all good
        console.log("All valid");
    }
    //clear error after x time to retry
    setTimeout(function() {
        $(".error").removeClass("error");
        $("input").removeAttr("data-btn-active") ;
    }, 3000);
}
window.selectBlur = function() {
    var input = $("#" + $(event.target).attr("data-btn"));
    validate(input);
}
window.selectChange = function() {
    var input = $("#" + $(event.target).attr("data-btn"));
    console.log("change", $(event.target).val() );
    input.val( $(event.target).val() );
    validate(input);
}
window.inputButtonClick = function() {
    var input = $("#" + $(event.target).attr("data-btn"));
    input.attr("data-btn-active", "true");
     console.log("inputButtonClick",input );
}
window.inputBlur = function() {
    var input = $(event.target);
    //give a bit of time for user to click on the button
    setTimeout(function() {
        if (!input.attr("data-btn-active" ) ) {validate(input);}
    }, 100);
}
$(document).ready(function() {

});