开发者

jQuery: Append once and stop (worked in older versions)

开发者 https://www.devze.com 2023-02-09 15:20 出处:网络
So here\'s the code I\'m using: $(function(){ $(\'<div id=\"info\" style=\"width:auto; height:auto;\"/>\').load(\'test.php?var=\'+d+\' #se\', function() {

So here's the code I'm using:

$(function(){
    $('<div id="info" style="width:auto; height:auto;"/>').load('test.php?var='+d+' #se', function() {
        $('#main').append(this);
    });
});
}

Now, when I trigger the function (with a keyup in a input box) the div loaded is appended over and over again on every keyup event.

I'm using jQuery 1.5 - in older versions, namely 1.2.6, the div wasn't appended after the first time and it worked fine (bug?).

How do I prevent the div from being appended over and over again? (disabling the "trigger" is not an option unfortunately.) I also tried appendTo, which is pretty开发者_JS百科 much the same problem.

Someone help me please! Thanks a lot


Sounds like you can use .one to bind your keyup handler:

$('whatever').one('keyup', function() {
    $('<div id="info" style="width:auto; height:auto;"/>').load('test.php?var='+d+' #se', function() {
        $('#main').append(this);
    });
});

The .one function acts just like .bind except that it unbinds itself after it executes once.


use

$(function(){
   if($("#info").length==0)
   {
      $('<div id="info" style="width:auto; height:auto;"/>').load('test.php?var='+d+' #se', function() {
        $('#main').append(this);
      });
   }
});
}

Assuming that "#info" is added dynamically.

0

精彩评论

暂无评论...
验证码 换一张
取 消