私はずっと、ブートストラップのmodal
のようなカスタムmodal
内PJAX
コンテナを再読み込みするいくつかの問題を抱えています。リロードPJAXのYii2を使用してモーダルダイアログ容器内部とjQuery
このコードの目的は、pjax
さんListview
内のすべての提出コメントをリロードするpjaxコンテナをリロードすることです。
初期リロードがjQuery
によって行われるが、jquery.pjax.js
で発生した例外が続いている:
jquery.pjax.js:740 Uncaught TypeError: Cannot read property '0' of null
:
if (fullDocument) {
var $head = $(parseHTML(data.match(/<head[^>]*>([\s\S.]*)<\/head>/i)[0]))
var $body = $(parseHTML(data.match(/<body[^>]*>([\s\S.]*)<\/body>/i)[0])) <-- error
} else {
var $head = $body = $(parseHTML(data))
}
マイビューのpjax:
<?php Pjax::begin([
'id'=>'pjax-post-comments',
'timeout' => 5000,
'enableReplaceState'=>false,
'enablePushState'=>false,
'clientOptions' => ['backdrop' => 'static', 'keyboard' => false],
]);?>
<?php
$query = $model->findComments();
$dataProvider = new ActiveDataProvider([
'query' => $query,
'pagination' => [
'pageSize' => 2, //for development reasons
],
]);?>
<div class='resp-col col-12 post-item-comment-history'>
<?=ListView::widget([
'dataProvider' => $dataProvider,
'summary'=>false,
'itemOptions' => [
'class' => 'comment-item'
],
'itemView' => '/frontend/comment/_item',
]);?>
</div>
<?php Pjax::end() ?>
pjaをリロードするために私のビューのjquery呼び出しx容器:
$('#submit-comment').on('click',function(){
event.preventDefault();
var user_id = '<?=Yii::$app->user->identity->id?>';
var content = $('#comment-content').val();
var post_id = '<?=$model->id?>';
var associative_id = $(this).data('assoc-id');
$.post('/frontend/post/submit-comment', {
user_id : user_id,
post_id : post_id,
content : content,
associative_id: associative_id
}, function(response){
if(response['response'] == true){
$('#comment-content').removeClass('error-form');
$('#comment-content').addClass('success-form');
$(this).data('assoc-id','null');
$('#comment-content').val('');
$.pjax.reload({container:"#pjax-post-comments",timeout: 5000});
}
else{
alert(response['errors']);
$('#comment-content').addClass('error-form');
$('#comment-content').removeClass('succes-form');
}
});
});
チェックサーバーの応答:THATの欠点はので、ここでそれ以外
$('#submit-comment').on('click',function());
は累積クリックします、私はクリックを毎回再初期化しなければならないことであることを修正する方法は? – Beowulfenator遅れて返信して申し訳ありません。あなたのコメントは正しい方向に私を指摘しました。受信したpjaxのURLがモーダルのURLと一致しませんでした。詳細は私の答えを見てください。 –