2016-05-03 10 views
0

何らかの理由で、まったく同じページの別のAjaxクリックイベントによって追加されたdivをAjaxクリックできません。別のAjaxクリックイベントによって追加されたdivでAjaxクリックイベントを実行する

両方のajaxリクエストは同じリクエストページを使用しますが、異なるデータ文字列を含みます。

これら

は私の2つのAjax機能で

$(document).ready(function(){ 
    $('#log_login').click(function(event){ 
     event.preventDefault(); 
     var email=$("#log_email").val(); 
     var login=$("#log_login").html(); 
     var dataString = 'email='+email+'&login='+login; 
     $.ajax({ 
      type: 'POST', 
      url: '$language_rewrite/$administrator_login/forgotpassword', 
      data: dataString, 
      beforeSend: function(){ 
       $("#login-msg").hide(); 
       $("#log_login").html('$translate_login_8...'); 
      }, 
      success: function(html){ 
       if(html){ 
        if(html.indexOf("$forgot_translate_1") > -1){ 
         $("#p_log_email").html('$forgot_translate_1'); 
         $("#log_verify_code").html('<input id="log_code" type="text" name="email" placeholder="$admin_f_subject"/><br>'); 
         $("#log_verify_btn").html('<div id="log_verify" name="login" class="standard-button">$admin_verify_btn</div>'); 
        } 
       } 
      }, 
      error: function(jqXHR, textStatus, errorThrown){ 
       alert('error'); 
      } 
     }); 
    }); 
}); 
$(document).ready(function(){ 
    $('#log_verify').click(function(event){ 
     event.preventDefault(); 
     var code = $("#log_code").val(); 
     var verify = $("#log_verify").html(); 
     var dataStringTwo = 'code='+code+'&verify='+verify; 
     $.ajax({ 
      type: 'POST', 
      url: '$language_rewrite/$administrator_login/forgotpassword', 
      data: dataStringTwo, 
      beforeSend: function(){ 
       $("#login-msg").hide(); 
       $("#log_verify").html('$admin_verify_btn...'); 
      }, 
      success: function(html){ 
       if(html){ 
        if(html.indexOf("1") > -1){ 
         $("#log-verify").html('<div id="log_login2" name="login" class="standard-button">FINISHED</div>'); 
        } 
       } 
      }, 
      error: function(jqXHR, textStatus, errorThrown){ 
       alert('error'); 
      } 
     }); 
    }); 
}); 

これは

<div id="log_verify_code"> 
    <input id="log_email" type="text" name="email" placeholder="<?php echo $translate_login_2; ?>"/><br> 
     <input id="log_code" type="hidden" value=""/> 
</div> 
<div id="log_verify_btn"> 
    <div id="log_login" name="login" class="standard-button"><?php echo $translate_login_8; ?></div> 
    <input id="log_verify" type="hidden" value=""/> 
</div> 

最初のAjax機能が完璧に動作変更されているHTMLコードであり、それは、入力フィールドを変更しますしかし、2番目のボタンを押すと何も起こりません。エラーでも、PHPエラーでもありません。何もない。どうして?

+1

はあなたがまだで存在しないオブジェクトにイベントリスナーをバインドしようとしていないよろしいですコメントしていた見ました拘束の時間? – Chris

+0

Ajaxコードはロード時に自動的にバインドされますか?アイテムがページに表示されても、それ自体は「再バインド」されませんか? – PhyCoMath

+1

いいえ、コードの内容を正確に分解した場合、読み込み時にID "log_verify"を持つすべての要素が見つかりますが、その中には何もありません(少し混乱しても "ログ検証"と呼ばれます)。彼らには何も結びついていないからです。 1つのオプションは、ドキュメント本体にバインドし、関心のある要素のイベントのみにフィルタリングすることです.JQueryはこれをサポートしています。 [on](http://api.jquery.com/on/)のドキュメントを参照してください。 – Chris

答えて

2

イベントハンドラは、既存の要素にのみバインドされます。将来の要素については、委任されたイベントを使用して、既存の祖先、または例えばドキュメント自体にバインドする必要があります。

$(document).on("click", ".future-elem", function() { 
    // code here 
}); 

出典:$.on - read: direct and delegated events

EDIT:ちょうどこれはすでに

+0

完璧に作業しました!なぜ、変更/削除されて再追加されている隠された要素へのバインディングが機能しないのですか? – PhyCoMath

+2

も削除するとハンドラが削除される(破棄される) – yezzz

+0

.htmlを使用するとhtmlが削除され、新しいhtmlに置き換えられると思います – yezzz

関連する問題