0

我想制作一个从右到左滑动的菜单,它是一个 h2 标题,并且当它从上到下信息完成时。如果在菜单已经存在的情况下单击不同的选项,则首先向上然后离开,如前所述。所以主要问题是,在某些方面需要出现 2 个信息而不是一个,我不知道该怎么做,所有这些都一个接一个地执行。如果使用回调,一些文本会出现两次或更多次......

$("a[rel~='showinfo']").click(function () {
  var info_id = $(this).attr('id');//getting needed id from menu to show info

  if($('.info_name').is(':visible'))//if already exists - removing
    remove_contact();

  for(i=0; i<contact_status.length; i++){//checking all array for item
    if(info_id == contact_status[i]){//if item exist 
        create_contact(i);//putting it in
        //here starts problems....
        $('#info_name'+i).show("slide", {direction: "right"}, 1000, function(){
            $('#info_info'+i).show("slide", {direction: "up"}, 1000);
        });
    }
  }
 //$('.info_name').show("slide", {direction: "right"}, 1000);
 //$('.info_info').show("slide", {direction: "up"}, 1000);

});

function create_contact(id){
    $('.third').append('<div class="showinfo"><h2 id="info_name'+id+'" class="info_name">'+contact_name[id]+'</h2><span class="info_info" id="info_info'+id+'">lol</span></div>')
}

function remove_contact() {
    $('.info_name').hide("slide", {direction: "right"}, 1000);
    $('.showinfo').remove();
}
4

1 回答 1

0
 for(i=0; i<contact_status.length; i++){//checking all array for item
    if(info_id == contact_status[i]){//if item exist 
        (function ( idx ) { // use a Anonymous funciton
             create_contact(idx );//putting it in
            //here starts problems....
            var;
            $('#info_name'+idx ).show("slide", {direction: "right"}, 1000, function(){
                $('#info_info'+idx ).show("slide", {direction: "up"}, 1000);
            });
        })( i );
    }
  }

啊,我错了……这次应该是对的

于 2012-04-04T15:08:42.233 回答