jquery需要替代focusout()

前端之家收集整理的这篇文章主要介绍了jquery需要替代focusout()前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
给定样本标记
  1. <div>
  2. <input />
  3. <input />
  4. <input />
  5. </div>

如何通过jQuery来确定div已经失去焦点?

我可以使用focusout(),但这不是我需要的.通过关注,它将被触发为输入到输入的一个选项卡,因为它实际上是通过事件冒泡来检测输入正在失去焦点.

另一种说明要求的方法:我需要知道焦点何时移动了外部的div.

以前我问过类似的问题:

jquery focusin() and preventing bubbling

但是这与一个弹出式UI相关联,可以通过在其后面插入一个空白DIV并将点击/焦点事件作为触发器来实现,但这对于这种情况将不起作用.

下一个想法是在调用focusout时测试focusin:

  1. $(".myobject").focusout(function(element) {
  2. if(!($(this).focusin())){
  3. console.log('doYourThing ' + $(this));
  4. }
  5. });

唉,这不行(我猜这是因为它在焦点事件中评估焦点,因此还没有检测到焦点.

任何聪明的解决这个问题?我可能会错过一个本来的jQuery事件,正是我正在寻找的?

更新:

其实简化的问题:

我需要等价于$(‘div’).blur(),但实际上可以在div上工作(因为模糊不能从div触发)

解决方法

那么,将“焦点”处理程序绑定到所有内容中可能会有什么工作,而且你知道什么时候不在< div>当您在其他地方获得“焦点”活动时.
  1. $('body').live('focus',(function() {
  2. var inDiv = false;
  3. return function(e) {
  4. if ($(this).closest('#theDiv').length)
  5. inDiv = true;
  6. else {
  7. if (inDiv)
  8. alert("just lost focus!");
  9. inDiv = false;
  10. }
  11. };
  12. });

猜你在找的jQuery相关文章