Yii学习笔记:利用setFlash和runController打造个性化的提示信息页面
博客专区 > 吾爱 的博客 > 博客详情
Yii学习笔记:利用setFlash和runController打造个性化的提示信息页面
吾爱 发表于4年前
Yii学习笔记:利用setFlash和runController打造个性化的提示信息页面
  • 发表于 4年前
  • 阅读 469
  • 收藏 2
  • 点赞 0
  • 评论 0
摘要: 通过Yii::success() Yii::error()实现提示信息页面

在实现Yii::success()这样的调用方式之前,你可能需要阅读我的这篇博文:

Yii学习笔记:扩展YiiBase入口类

之后请继续往下看:

首先我们在yii.php的Yii类里面添加两个方法:

/**
     * 成功提示
     * @param type $msg 提示信息
     * @param type $jumpurl 跳转url
     * @param type $wait 等待时间
     */
    static function success($msg="",$jumpurl="",$wait=3){
        self::_jump($msg, $jumpurl, $wait, 1);
    }
    /**
     * 错误提示
     * @param type $msg 提示信息
     * @param type $jumpurl 跳转url
     * @param type $wait 等待时间
     */
    static function error($msg="",$jumpurl="",$wait=3){
        self::_jump($msg, $jumpurl, $wait, 0);
    }
    /**
     * 最终跳转处理
     * @param type $msg 提示信息
     * @param type $jumpurl 跳转url
     * @param type $wait 等待时间
     * @param int $type 消息类型 0或1
     */
    static private function _jump($msg="",$jumpurl="",$wait=3,$type=0){
        $info = array(
            'msg' => $msg,
            'jumpurl' => $jumpurl,
            'wait' => $wait,
            'type' => $type
        );
        Yii::app()->user->setFlash('showmessage',$info);
        Yii::app()->runController("Site/ShowMessage");
    }



调用的时候可以指定 消息内容、跳转地址、停留时间。

继续,在应用默认的 SiteController 中添加如下方法:

        /**
         * 提示信息
         */
        public function actionShowMessage(){
            $data = Yii::app()->user->getFlash('showmessage');//flash中读取提示信息
            if(empty($data) || !is_array($data) || !isset($data['msg']) || $data['msg']==""){
                Yii::app()->end();
            }
            if(!isset($data['wait'])){
               $data['wait'] = 3;
            }
            if(!isset($data['type'])){
               $data['type'] = 1;
            }
            $data['title'] = ($data['type']==1) ? "提示信息" : "错误信息";
            if(!isset($data['jumpurl']) || empty($data['jumpurl'])){
                if($data['type']==1){
                    $data['jumpurl']=isset($_SERVER['HTTP_REFERER'])?$_SERVER['HTTP_REFERER']:"javascript:window.close();";
                }else{
                    $data['jumpurl'] = "javascript:history.back(-1);";
                }
            }
            $this->renderPartial("show_message",$data);
        }



在其对应的视图目录中添加视图文件 show_message.php:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>跳转提示</title>
<style type="text/css">
*{ padding: 0; margin: 0; }
body{ background: #fff; font-family: '微软雅黑'; color: #333; font-size: 16px; }
.system-message{ width:500px;height:100px; margin:auto;border:6px solid #999;text-align:center; position:relative;top:50px;}
.system-message legend{font-size:24px;font-weight:bold;color:#999;margin:auto;width:100px;}
.system-message h1{ font-size: 100px; font-weight: normal; line-height: 120px; margin-bottom: 12px; }
.system-message .jump{ padding-right:10px;height:25px;line-height:25px;font-size:14px;position:absolute;bottom:0px;left:0px;background-color:#e6e6e1 ; display:block;width:490px;text-align:right;}
.system-message .jump a{ color: #333;}
.system-message .success,.system-message .error{ line-height: 1.8em; font-size: 15px }
.system-message .detail{ font-size: 12px; line-height: 20px; margin-top: 12px; display:none}
</style>
</head>
<body>
<fieldset class="system-message">
    <legend><?php echo $title;?></legend>
    <div style="text-align:left;padding-left:10px;height:75px;width:490px;  ">
        
        <?php if($type==1):?>
        <p class="success">恭喜^_^!~<?php echo($msg); ?></p>
        <?php else:?>
        <p class="error">Sorry!~<?php echo($msg); ?></p>
        <?php endif;?>
        <p class="detail"></p>
        
    </div>
    <p class="jump">
        页面自动 <a id="href" href="<?php echo($jumpurl); ?>">跳转</a> 等待时间: <b id="wait"><?php echo($wait); ?></b>
    </p>
</fieldset>
<script type="text/javascript">
    
(function(){
var wait = document.getElementById('wait'),href = document.getElementById('href').href;
totaltime=parseInt(wait.innerHTML);
var interval = setInterval(function(){
	var time = --totaltime;
        wait.innerHTML=""+time;
	if(time === 0) {
		location.href = href;
		clearInterval(interval);
	};
}, 1000);
})();

</script>
</body>
</html>



到这里就完成了。

实例:

<?php
class PublicController extends CustomController {
    public function actionLogin(){
        $this->title = "商户后台登录";
        if(Yii::app()->request->isPostRequest){
            $identify = new CustomIdentity("admin","passwd");
            if($identify->authenticate() == true){
                Yii:app()->user->login($identify);
            }else{
                Yii::error("用户名或密码错误");
            }
        }else{
            $this->render('login');
        }
    }
}



效果图:


文章原创,转载请注明出处

标签: Yii学习笔记
共有 人打赏支持
粉丝 141
博文 250
码字总数 86884
×
吾爱
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: