jQuery .on keyup and blur firing onload only

2019-03-16 02:53发布

Problem: The blur and keyup events each fire once onload, and only onload. How can I get them to work correctly?

jQuery:

function myFunction(text){
    alert(text);
}
$('#input1').on({
    keyup: myFunction('keyup'),
    blur: myFunction('blur'),
    focus: function(){console.log('focus!');}
});

Fiddle: http://jsfiddle.net/GrMQX/

5条回答
贼婆χ
2楼-- · 2019-03-16 03:09

You need to pass a function as an argument.. you are passing the return value of the called function

function myFunction(text){
    alert(text);
}
$('#input1').on({
    keyup: function(){myFunction('keyup');},
    blur: function(){myFunction('blur');},
    focus: function(){console.log('focus!');}
});

Or you can convert your myFunction to a function generator

function myFunction(text){
   return function(){
       console.log(text);
   }
}

$('#input1').on({
    keyup: myFunction('keyup'),
    blur: myFunction('blur'),
    focus: function(){console.log('focus!');}
});

Demo at http://jsfiddle.net/gaby/GrMQX/6/

查看更多
虎瘦雄心在
3楼-- · 2019-03-16 03:11

You are not assigning a function to keyup and blur, you're assigning the result of the execution of myFunction.

Change it like this:

$('#input1').on({
    keyup: function() { myFunction('keyup'); },
    blur:  function() { myFunction('blur'); },
    focus: function() { console.log('focus!'); }
});

DEMO

查看更多
Melony?
4楼-- · 2019-03-16 03:12

You're not declaring the functions as callbacks, you're executing them and their return result is assigned as a callback (which doens't work).

Try this:

  $('#input1').on({
    keyup: function() { myFunction('keyup') },
    blur: function() { myFunction('blur') },
    focus: function(){console.log('focus!');}
  });
查看更多
做个烂人
5楼-- · 2019-03-16 03:17

use with .on() Event

$(document).on("keyup blur", "#input1", function(event)
    {       
    // your code        

    });
查看更多
可以哭但决不认输i
6楼-- · 2019-03-16 03:20

You're actually executing the functions when you call them that way. Try this:

$('#input1').on({
    keyup: function(){myFunction('keyup')},
    blur: function(){myFunction('blur')},
    focus: function(){console.log('focus!');}
});

jsFiddle example

查看更多
登录 后发表回答