2011-07-26 9 views
0

以下のコードを使用して、私はポップアップウィンドウを表示しています。私はアニメーションメソッドtoggle()を使用しました。しかし、ポップアップウィンドウは一度しか表示されません。理由は何ですか?どうすればこの問題を解決できますか?私のプログラムでtoggle()メソッドが正しく動作しないのはなぜですか?

コード:

$(document).ready(function() 
{ 
     $(".ishow").click(function() 
     { 
      var info=$(this).attr("id"); 
      var id=info.replace("/",""); 

      var cor=$(".rd"+id).offset(); 
      var x=cor.left; 
      var y=cor.top; 

      $.ajax 
      ({ 
       type:"post", 
       url:"roomstaypopup.php", 
       data:"id="+info, 
       success: function(html) 
       {       
        $("#popup"+id).css({"display":"block","left":x-51,"top":y+18}); 
        $("#popup"+id).toggle(); 
        $("#popup"+id).html(html); 
       } 
      }); 

     }); 
}) 
+1

あなたのHTMLを提供してください –

+0

実際には、すべての '。popupX'要素'要素?また、なぜトグルするのですか?あなたは 'display:block'を設定してから' toggle'を呼び出す必要があります。これはあなたが望むようには見えない要素を隠すべきです**。 –

答えて

3

.toggle()の直前にスタイルを「表示」:「ブロック」に設定すると、.toggle()は常に要素を非表示にします。

"display":"block",を削除してみてください。また.toggle(500);のような期間を追加しない限り、.toggle()はアニメーション化されません。しかし、あなたの目的のために、.toggle(500);の代わりに.show();を使用し、show();またはtoggle();への呼び出しの前に$("#popup"+id).html(html);を入れて、アニメーションの開始前にhtmlが挿入されていることを確認してください。

+0

Paulに感謝します。今私のプログラムは正常に動作しています。 – Hearaman

+0

@Hearaman私が助けることができるとうれしいです:) – Paulpro

+0

@Hearamanあなたの問題を解決した場合は、この答えを受け入れるようにしてください。 :-) – GregL

1

私はトグルが最終的に表示CSSの属性を変更するかなり確信しています。 #popup + idの.css設定がトグルに干渉していないことを確認してください。

トグルは、最初のクリックを表示し、次のクリックを非表示にする必要があります。しかし、toggle()がトリガーされる直前にCSSで表示すると、毎回オフに切り替えることがあります。

上記のトグル()の行をコメントアウトしてください。とにかくそれは私の推測です。

0

トグルは、可視性に応じて要素を表示または非表示にするため、言い換えれば機能します。あなたの場合は、display = blockの要素でそれを呼び出すので、常にdisplayをnoneにするように設定する必要があります。