阐述在Yii2上实现跳转提示页
序言
为了让用户有更加良好的体验,在操作成功或者失败后,来个提示并跳转页面,我就在Yii2上实现了这一个效果。在写这个跳转提示页的时候,找资料我发现网上关于这方面的中文资料真的很少,大家也都共享下吧!
需求分析
1、用户在操作成功或者失败后,来个提示并跳转页面。
2、使用这种方式$this->success(),$this->error()调用(仿造Yii2自带 $this->render()加载页面的方式)。
效果图
样式有点丑,但是功能是好的,要是不喜欢这样式大家可以自行美化一下!
代码分析
1、在控制器的基类Controller.php里边增加两个方法,这么写:
/
- 通用成功跳转
- @param unknown $url 成功后跳转的URL
- @param number $sec 自动跳转秒数
- @return Ambigous
*/
public function success($url= [] ,$sec = 3){
$url= empty($url)? ['/admin/main']: $url;
$url= \yii\helpers\Url::toRoute($url);
return $this->renderPartial('../base/msg',['gotoUrl'=>$url,'sec'=>$sec]);
}
/ * 通用错误跳转 * @param string $msg 错误提示信息 * @param number $sec * @return Ambigous */public function error($msg= '',$sec = 3){ return $this->renderPartial('../base/msg',['errorMessage'=>$msg,'sec'=>$sec]);}
2、在loginviewsbase的下面建立一个命名为msg.php的页面,代码如下:
'.$errorMessage.'
';?>
恭喜!操作成功!该页将在3秒后自动跳转! ">立即跳转 返回上一页
.page-none-alert{margin: 100px 0 !important;
text-align: center !important;
font-size: 30px !important;}
setInterval("history.go(-1);",000);
setInterval("window.location.href=''",000);
3、完成以上步骤之后就可以在login模块下的控制器里边直接调用了,调用方式如下:
成功的调用方式: return $this->success(['/site/login']);
失败的调用方式: return $this->error('数据修改失败!');
常见问题
1、跳转提示的JS写在如下我注释的地方了,写在那的话就不起作用了,得写在外面才行。
beginBlock('JUMP_JS')?>
(function(){
//跳转提示的JS写在这了。不能写在这,写在这里就不起作用了。
});
endBlock();
$this->registerJs($this->blocks['JUMP_JS'],\yii\web\view::POS_END);?>
相关资料
Yii2跳转提示页的写法:http://www.yiifans.com/forum.php?mod=viewthread&tid=11243
关键字:php, css, node.js, html5
版权声明
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处。如若内容有涉嫌抄袭侵权/违法违规/事实不符,请点击 举报 进行投诉反馈!