2011-01-17 36 views
2

htmlページには、いくつかのオプションがあります。
オプションを選択すると、ajax呼び出しがオプションの値をPHPスクリプトに渡します。このスクリプトは、ページに追加された特定のIDを持つHTMLフラグメント(別の選択)を返します。JQueryで動的に追加されたhtml要素を削除する

ユーザーが最初の選択肢から別のオプションを選択すると、イベントが再度発生し、ajax呼び出しが実行され、別のhtmlフラグメント(同じIDを持つ)がページに追加されます。

もう一度イベントが発生すると、追加された要素がページから削除されてから、新しい要素が追加されます。これはしかし動作していない

$(document).ready(function() { 
    $("#id_serie").change(function() { //#id_serie is the if of the first select 
     if ($("#id_subserie_label")) { //#id_subserie_label is the id of the html element returned by the ajax call 
      console.log("Removing"); 
      $("#id_subserie_label").empty().remove(); 
     } 
     var url = 'myscript.php'; 
     var id_s = $(this).val(); 
     $.post(url, {id_serie: id_s}, function(data) { 
      $("#id_serie").parent().after(data); 
     }); 
    }); 
}); 

要素は最初の呼び出し(なぜなら要素から返された後、第二AJAX呼び出しによって返されたHTML要素が追加されます:私はこのコードを使用しています現時点では

id#id_subserie_labelは、スクリプトがロードされてもページに表示されません)。

私は必要なものをどのように達成できますか?

+1

マット・ボールの答えが正しい理由を、そのjQueryのです$()関数は、探している要素を見つけることができるかどうかにかかわらず、常にjQueryオブジェクトを返します。 .lengthプロパティは、見つかった要素の数を示します。 – jessegavin

答えて

2

あなたは非常に近いです。

ただif ($("#id_subserie_label").length)if ($("#id_subserie_label"))を変更します。

$(document).ready(function() { 
    $("#id_serie").change(function() { 
     if ($("#id_subserie_label").length) { // <=== change this line 
      console.log("Removing"); 
      $("#id_subserie_label").empty().remove(); 
     } 
     var url = 'myscript.php'; 
     var id_s = $(this).val(); 
     $.post(url, {id_serie: id_s}, function(data) { 
      $("#id_serie").parent().after(data); 
     }); 
    }); 
}); 

The jQuery FAQ: How do I test whether an element exists?を参照してください。


Ivoが指摘するように、これは、次のとおりです。

$("#id_subserie_label")はオブジェクトであり、オブジェクトは常にtrueに評価されます。 Andy E'sコメントを1として


あなたがconsole.log()呼び出し必要がない場合、あなたは、このようにコードを簡素化することができます。

$(document).ready(function() { 
    $("#id_serie").change(function() { 
     $("#id_subserie_label").empty().remove(); 
     var url = 'myscript.php'; 
     var id_s = $(this).val(); 
     $.post(url, {id_serie: id_s}, function(data) { 
      $("#id_serie").parent().after(data); 
     }); 
    }); 
}); 
+1

説明のために: '$("#id_subserie_label ")'はオブジェクトであり、オブジェクトは常に 'true'と評価されます。 –

+1

'if'文は' console.log'呼び出しのために本当に必要です。それ以外の場合、jQueryは長さが0より大きい場合、一致するセット内の要素を空にしたり削除したりするので、全く必要ありません。 –

+0

@Andy:そうです、それは良い点です。 –