微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

jquery – 焦点输出事件后未触发的Click事件

在Focusout事件之后,不会触发click事件.

我的设计是,

<textarea id="txt"></textarea>
<input type="button" id="btnClick" value="Submit" />

jQuery的,

$(document).ready(function () {
var field = $("#txt");
var btn = $("#btnClick");
field.on("focusin",f1);
field.on("focusout",f2);
btn.on("click",f3);

function f1() {
    field.removeClass("c1").addClass("c2");
}

function f2() {
    field.removeClass("c2").addClass("c1");
}

function f3() {
    alert('hi');
}
});

样式,

.c1 { height:40px; }
.c2 { height:250px;}

而且我还附上了fiddle here.

解决方法

那是因为它没有足够的时间让按钮移动位置触发点击.如果您按住mousedown并将鼠标移动到按钮并点击该按钮,您可以看到点击有效,您将看到点击工作.

要么使用btn.on(‘mousedown’,f3);或定位按钮,使焦点不会移动

DEMO mousedown

DEMO button positioned

点击工作的方式是你在元素和鼠标上都有mousedown,也就是当它触发点击时

原文地址:https://www.jb51.cc/jquery/177517.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐