Выключение оповещений при нажатии кнопки - PullRequest
8 голосов
/ 08 февраля 2012

Когда я нажимаю кнопку, оповещения не выполняются. Что я делаю неправильно? Может быть, мне нужно включить некоторые файлы js в мой раздел заголовка?

Вот мой вид для входа в систему:

<?php echo CHtml::beginForm(); ?>

<div class="row">
<?php echo CHtml::label('username', 'username'); ?>
<?php echo CHtml::textField('username'); ?>
</div>
<div class="row">
<?php echo CHtml::label('password', 'password'); ?>
<?php echo CHtml::textField('password'); ?>
</div>
<?php
echo CHtml::ajaxButton('sign in', array('site/login'),array(
        'type'=>'POST',
        'update'=>'#mydiv',
        'beforeSend' => 'function(){
            alert("beforeSend");
        }',
        'complete' => 'function(){
            alert("complete");
            }',

));
?>
<?php echo CHtml::endForm(); ?>
<div id="mydiv" style="color:white;">...</div>

Вот мой код в контроллере:

public function actionLogin()
{
    $this->renderPartial('//blocks/user_info');
}

user_info просто повторяет some text

Ответы [ 9 ]

6 голосов
/ 04 июля 2012

Не уверен, что это ваша проблема, но renderPartial () плохо работает с AJAX.Это известная проблема Yii:

http://www.yiiframework.com/forum/index.php/topic/24699-yii-20-ajaxrenderpartial-conflict/ http://www.yiiframework.com/forum/index.php?/topic/10427-ajax-clientscript

Я столкнулся с проблемой, когда попытался загрузить форму через AJAX, а затем отправить ее обратно с помощью CHtml :: ajaxSubmitButton.

3 голосов
/ 22 октября 2012

в моем коде это работает, попробуйте это

<?php
echo CHtml::ajaxSubmitButton('Save','your-url',array(
   'type'=>'POST',
   'dataType'=>'json',
   'success'=>'js:function(data){
       if(data.result==="success"){
          // do something on success, like redirect
       }else{
         $("#some-container").html(data.msg);
       }
   }',
));
?>
3 голосов
/ 22 августа 2012

попробуйте

this->renderPartial('//blocks/user_info','', false, true);

1 голос
/ 24 сентября 2013

Это простой пример кнопки отправки Yii Ajax:

<?php
echo CHtml::ajaxSubmitButton(
'Submit',
'your-url',
array(
   'type'=>'POST',
   'dataType'=>'json',
   'success'=>'js:function(data){
       if(data.result==="success"){
          // do something on success, like redirect
       }else{
         $("#some-container").html(data.msg);
       }
   }',
)
);
?>

Подробнее на http://www.codexamples.com/90/chtml-ajaxsubmitbutton/

1 голос
/ 18 августа 2012

У меня тоже есть эта проблема (ошибка?). Попробуйте изменить 'beforeSend' и другие обратные вызовы в этом представлении:

'beforeSend':'js:alert("complete");'

без "function () {}" и с "js".

P.S. Извините, мой английский плохой (

1 голос
/ 08 февраля 2012

До отправки работает? Что если вы попробуете «успех» вместо «завершить»?

0 голосов
/ 03 июля 2015

В функции контроллера необходимо отправить еще 3 параметра (всего 4 параметра)

ваша функция будет такой

public function actionLogin()
{
  this->renderPartial('//blocks/user_info','',false,true);
}
0 голосов
/ 24 февраля 2015

Вы должны установить для четвертого параметра функции renderPartial значение true, чтобы Yii включал необходимые JS-файлы для правильной работы представления.

$this->renderPartial('_form',array('model'=>$model), false, true);
0 голосов
/ 20 января 2015

Кнопка отправки Ajax в поле зрения:

echo CHtml::ajaxSubmitButton('Save', array('/controller/action/id/' .     $id), array(
                'type' => 'post',
                'dataType' => 'json',
                'update' => '#mydiv',
                'beforeSend' => 'function(){}',
                'complete' => 'function(){}',
                'success' => 'js:function(data){
                    if(data.status=="1"){
                        html = "<div class=\"alert in alert-block fade alert-success\"><a class=\"close\" data-dismiss=\"alert\">x</a>"+data.msg+"</div>";
                        $("#status-msg").html(html);

                        }else{
                        html = "<div class=\"alert in alert-block fade alert-error\"><a class=\"close\" data-dismiss=\"alert\">x</a>"+data.msg+"</div>";
                        $("#status-msg").html(html);
                        }
                    }',
                    ), array('class' => "btn btn-primary")
            );

В действии контроллера:

        $return = array();
        $return['status'] = '1';
        $return['msg'] = 'Record Updated Successfully';

        echo CJSON::encode($return);
        Yii::app()->end();

Изменить массив возвращаемых данных в соответствии с требованием.

...