コントローラー アクションで ajax リクエストへの応答としてパーシャルをレンダリングしたいと思います。私の目標は、ajax リクエストが成功したときにTwitter Bootstrap Alertをエコーすることです。
これが私のアクションです(redigeraLottningAction
):
if($this->getRequest()->isXmlHttpRequest()){
$this->_helper->viewRenderer->setNoRender();
$this->_helper->layout->disableLayout();
echo $this->view->partial('partial/alert-ajax.phtml', array('type' => 'success', 'msg' => 'Lyckat! Lottningen är nu sparad.'));
}
そして私の部分(alert-ajax.phtml
):
<div id="alert-msg" class="alert alert-<?= $this->type?> fade in">
<a class="close" data-dismiss="alert" href="#">×</a>
<p><?= $this->msg?></p>
</div>
問題は、パーシャルの php スクリプトがテキストとして出力されることです。これは、変数がレンダリングされていない状態でブラウザに表示されるものです。
<div id="alert-msg" class="alert alert-<?= $this->type?> fade in">
<a class="close" data-dismiss="alert" href="#">×</a>
<p><?= $this->msg?></p>
</div>
そしてjquery部分:
$(document).ready(function(){
$('#lottning-spara').click(function () {
$.ajax({
type: "POST",
url: '/turnering/redigera-lottning',
cache: false,
data: {id: getParam("turnering"), klass_id: getParam("klass"), type: "spara", lottning: $('#lottning_str').val()},
dataType: 'html',
success: function(msg){
$('#alert-div').html(msg);
},
error: function(){
$('#alert-div').html('Error!');
}
});
});
});
部分的なphpがレンダリングされない理由はありますか??
編集は太字です。
問題が解決しました。alert-ajax.phtml ファイルは異なる文字セット タイプでした。