Ajax 调用 yii 对话框关闭函数失败



>我在使用ajax调用对话框关闭函数时遇到了这个问题。

这是我的 ajax 调用函数:

function samplefunction(var1,var2){     
    $.ajax({
        url: "controllerFunction?var1="+var1+"&var2="+var2,
        type: 'POST',
        dataType: 'json',
        success: function(data)
        {
            $("#htmlmessage").html(data.message);
            $("#htmlmsgdialog").dialog("open");
        }
    });
}

下面是对话框代码:

<?php 
$this->beginWidget('zii.widgets.jui.CJuiDialog',array(
    'id'=>'sampledialogboxname',
    'options'=>array(
        'title'=>'Sample Dialog Box I',
        'autoOpen'=>false,
        'modal'=>true,
        'resizable'=>false,
        'draggable'=>false,
        'position'=>array("middle",30),
        'width'=>650,
        'show'=>'fade',
        'hide'=>'fade',
        'open' => 'js:function(event,ui){
                      //some code here
        }',
        **'close' => 'js:function(event,ui){
                        samplefunction("samplestring1","samplestring2");
                        window.location.href = "'.$sampleurl.'";
        }',**
        'buttons' => array
        (
            array('id' => 'firstback','text'=>'BACK',
                        'click'=> 'js:function(){
                                    samplefunction("samplestring1","samplestring2");
                                    $(this).dialog("close");
                                    window.location.href = "'.$sampleurl.'";
                        }'),
            array('id' => 'secondback','text'=>'BACK','click'=> 'js:function(){
                                    //some code here
                        }'),
            array('id' => 'thirdback','text'=>'BACK','click'=> 'js:function(){
                                    //some code here
                        }'),
            array('id' => 'fourthback','text'=>'BACK','click'=> 'js:function(){
                                    //some code here
                        }'),
            array('id' => 'firstnext','text'=>'NEXT','click'=> 'js:function(){
                                    //some code here
                        }'),
            array('id' => 'secondnext','text'=>'NEXT','click'=> 'js:function(){
                                    //some code here
                        }'),
            array('id' => 'thirdnext','text'=>'NEXT','click'=> 'js:function(){
                                    //some code here
                        }'),
            array('id' => 'save','text'=>'SAVE','click'=> 'js:function(){
                                    //some code here  
                        }')
        ),
    ),
));?>

下面是控制器功能:

public function actionControllerFunction($var1, $var2)
{
    var_dump($var1, $var2);
    //Do Some Code here
    $result['showdialog'] = true;
    $result['message'] = "Sample Msg.";
    echo json_encode($result);
    exit;
}

我的问题是,即使在我进入控制器函数之前,ajax 调用也总是失败。我检查了我的参数,它也具有要传递的适当字符串。我非常需要帮助。非常感谢任何有助于我的评论。谢谢。(^__^)

我认为你最好的选择是通过ajax函数修复你正在访问的网址:

在视图中的文件

$sampleurl=Yii::app()->createUrl("controllerName/sampleFun");
$ajaxFun=Yii::app()->createUrl("controllerName/controllerFunction");
$ajaxReq = <<<JS
function samplefunction(var1,var2 ,dlg,refreshUrl){     
    $.ajax({
        url: "$ajaxFun&var1="+var1+"&var2="+var2,
        type: 'POST',
        dataType: 'json',
        success: function(data)
        {
            $("#htmlmessage").html(data.message);
            $("#htmlmsgdialog").dialog("open");
        }
    });
    if(dlg!=null ) $(dlg).dialog('close');
    //window.location.href=refreshUrl
}
JS;

注意网址:url: "$ajaxFun&var1="+var1+"&var2="+var2,

给出上下文控制器是SiteController它的 ajax url 应该是这样的:

site/controllerFunction&var1=abc&var2=def

完整的网址将是:

index.php?r=site/controllerFunction&var1=abc&var2=def

在您的情况下,您错误地放置了

index.php?r=site/controllerFunction?var1=abc&var2=def

注意两个(?),这显然是错误的。

一个建议:

  1. 通过删除参数来修复函数

    public function actionControllerFunction(){ //use $_POST array .... }

  2. 将数据作为从 ajax 方法的发布数据发送 function samplefunction(var1,var2 ,dlg,refreshUrl){

    $.ajax({
        url: "$ajaxFun",
        data:"&var1="+var1+"&var2="+var2",
        type: 'POST',
        dataType: 'json',
        success: function(data)
        {
            $("#htmlmessage").html(data.message);
            $("#htmlmsgdialog").dialog("open");
        }
    });
    

    url: "$ajaxFun",data:"&var1="+var1+"&var2="+var2",

希望这会有所帮助 进一步阅读

最新更新