在应用开发中,常常会遇到一些带有提示信息的跳转页面,例如操做成功或者操做错误页面,而且自动跳转到另一个目标页面。系统的\Think\Controller类内置了两个跳转方法success和error,用于页面跳转提示,并且能够支持ajax提交。javascript
使用方法很简单,举例以下:php
$User = M('User'); //实例化User对象
$result = $User->add($data);
if($result){
//设置成功后跳转页面的地址,默认的返回页面是$_SERVER['HTTP_REFERER']
$this->success('新增成功', 'User/list');
} else {
//错误页面的默认跳转页面是返回前一页,一般不须要设置
$this->error('新增失败');
}
success和error方法的第一个参数表示提示信息,第二个参数表示跳转地址,第三个参数是跳转时间(单位为秒),例如:html
// 操做完成3秒后跳转到 /Article/index
$this->success('操做完成','/Article/index',3);
// 操做失败5秒后跳转到 /Article/error
$this->error('操做失败','/Article/error',5);
跳转地址是可选的,success方法的默认跳转地址是$_SERVER["HTTP_REFERER"]
,error方法的默认跳转地址是javascript:history.back(-1);
。java
默认的等待时间success方法是1秒,error方法是3秒ajax
success
和error
方法均可以对应的模板,默认的设置是两个方法对应的模板都是:thinkphp
//默认错误跳转对应的模板文件
'TMPL_ACTION_ERROR' => THINK_PATH . 'Tpl/dispatch_jump.tpl',
//默认成功跳转对应的模板文件
'TMPL_ACTION_SUCCESS' => THINK_PATH . 'Tpl/dispatch_jump.tpl',
也能够使用项目内部的模板文件函数
//默认错误跳转对应的模板文件
'TMPL_ACTION_ERROR' => 'Public:error';
//默认成功跳转对应的模板文件
'TMPL_ACTION_SUCCESS' => 'Public:success';
模板文件能够使用模板标签,而且能够使用下面的模板变量:ui
变量 | 含义 |
---|---|
$msgTitle | 操做标题 |
$message | 页面提示信息 |
$status | 操做状态 1表示成功 0 表示失败 具体还能够由项目自己定义规则 |
$waitSecond | 跳转等待时间 单位为秒 |
$jumpUrl | 跳转页面地址 |
success和error方法会自动判断当前请求是否属于Ajax请求,若是属于Ajax请求则会调用ajaxReturn方法返回信息。 ajax方式下面,success和error方法会封装下面的数据返回:this
$data['info'] = $message; // 提示信息内容
$data['status'] = $status; // 状态 若是是success是1 error 是0
$data['url'] = $jumpUrl; // 成功或者错误的跳转地址
Controller类的redirect方法能够实现页面的重定向功能。url
redirect方法的参数用法和U函数的用法一致(参考URL生成部分),例如:
//重定向到New模块的Category操做
$this->redirect('New/category', array('cate_id' => 2), 5, '页面跳转中...');
上面的用法是停留5秒后跳转到New模块的category操做,而且显示页面跳转中字样,重定向后会改变当前的URL地址。
若是你仅仅是想重定向要一个指定的URL地址,而不是到某个模块的操做方法,能够直接使用redirect
函数重定向,例如:
//重定向到指定的URL地址
redirect('/New/category/cate_id/2', 5, '页面跳转中...')
Redirect函数的第一个参数是一个URL地址。
控制器的redirect方法和redirect函数的区别在于前者是用URL规则定义跳转地址,后者是一个纯粹的URL地址。