找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 590|回复: 0
打印 上一主题 下一主题

Yii使用ajax验证显示错误messagebox的解决方法

[复制链接]

2500

主题

2513

帖子

7520

积分

论坛元老

Rank: 8Rank: 8

积分
7520
跳转到指定楼层
楼主
发表于 2018-2-14 05:51:44 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            本文实例讲述了Yii使用ajax验证显示错误messagebox的解决方法。分享给大家供大家参考。具体方法如下:
yii 自带了ajax 表单验证 这个可能有些朋友不知道了,但我今天在使用yii 自带的ajax 表单验证 时碰到一些问题,下面我来整理例子与大家参考一下。
在Yii中,可以利用ajax执行一个action,但是这个action有时候会有弹出错误讯息的需求,这时候的处理方式如下
基本思想
利用exception,比如:
[U]复制代码[/U] 代码如下:throw new CHttpException(403, 'You are not authorized to perform this action.');
如果这个异常是 CHttpException 或者 YII_DEBUG 为 true的时候,错误消息可以通过CErrorHandler::errorAction来显示。在yiic默认生成的代码中,就是通过在 config/main.php 中加入如下代码来实现的
[U]复制代码[/U] 代码如下:'errorHandler' => array(
    'errorAction' => 'site/error',),
但是在Yii  1.1.9 以上,ajax请求抛出的exceptions是通过CApplication::displayException()来显示的。这使得我们无法定制消息的显示方式。
CGridView 删除请求抛出异常的话就是这个样子,(YII_DEBUG 为 true )
Yii 1.1.9 检查ajax请求的逻辑被移除了,所以现在即便是ajax的异常也是通过CErrorHandler::errorAction处理的。
这样ajax的消息就可以DIY了。
示例
通过如下代码
[U]复制代码[/U] 代码如下:public function actionError(){
    if($error=Yii::app()->errorHandler->error)
    {
        if(Yii::app()->request->isAjaxRequest)
            echo $error['message'];
else
            $this->render('error', $error);
    }
}
后来又发现一个站长分享了一段代码
model:
[U]复制代码[/U] 代码如下:public function rules()
{
        // NOTE: you should only define rules for those attributes that
        // will receive user inputs.
        return array(
            array('content, author, email', 'required'),
            array('author, email, url', 'length', 'max'=>128),
            array('email','email'),
            array('url','url'),
        );
}
controller:
[U]复制代码[/U] 代码如下:if(isset($_POST['ajax']) && $_POST['ajax']==='comment-form')
{
    echo CActiveForm::validate($model);
    Yii::app()->end();
}
view:
[U]复制代码[/U] 代码如下:beginWidget('CActiveForm',array(
    'id'=>'post-form',                      //这是表单id
    'enableAjaxValidation'=>true,      //这里一定写 true
)); ?>
   
   
        labelEx($model,'title');
?>
        textField($model,'title',array('size'=>80,'maxlength'=>128));
?>
        error($model,'title');
?>
   
   
        labelEx($model,'content');
?>
        10, 'cols'=>70));
?>
        You may use Markdown syntax.
        error($model,'content');
?>
   

endWidget();
?>
这样好像很好的解决了yii ajax显示问题。
希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。
            
            
您可能感兴趣的文章:
  • ajax翻页效果模仿yii框架自己写的
  • 使用Yii整合的pjax(pushstate+ajax)实现无刷新加载页面
  • Yii2实现ajax上传图片插件用法
  • yii2使用ajax返回json的实现方法
  • Yii2.0 模态弹出框+ajax提交表单
  • yii2 modal弹窗之ActiveForm ajax表单异步验证
  • Yii+upload实现AJAX上传图片的方法
  • Yii基于CActiveForm的Ajax数据验证用法示例
  • yii2控制器Controller Ajax操作示例
  • Yii2基于Ajax自动获取表单数据的方法
  • Yii框架结合sphinx,Ajax实现搜索分页功能示例
  • Yii2表单事件之Ajax提交实现方法
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端