jquery:在keyup上执行此操作,除非此人在textarea或输入中

前端之家收集整理的这篇文章主要介绍了jquery:在keyup上执行此操作,除非此人在textarea或输入中前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我的脚本工作,但我不明白如何使它在textarea /输入和按下这些键时不启动功能. aka:当用户按下该键时启动事件,除非用户在textarea / input中.
  1. $('body').keyup(function (event) {
  2.  
  3. var direction = null;
  4. if (event.keyCode == 37) {
  5. $('#wrapper').fadeOut(500)
  6. } else if (event.keyCode == 39) {
  7. $('html,body').animate({scrollTop: $('body').offset().top},{duration: 1500,easing: 'easeInOutQuart'}
  8. )
  9. return false;
  10. }
  11. })

解决方法

只需检查event.target:
  1. $('body').keyup(function(event) {
  2. if ($(event.target).is(':not(input,textarea)')) {
  3. ...
  4. }
  5. });

在这种情况下,您仍然只有一个事件处理程序(附加到正文),但它将过滤接收事件的元素

猜你在找的jQuery相关文章