多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
#### 页面跳转 在应用开发中,经常会遇到一些带有提示信息的跳转页面,例如操作成功或者操作错误页面,并且自动跳转到另外一个目标页面。系统的`\think\Controller`类内置了两个跳转方法`success`和`error`,用于页面跳转提示。 跳转方法可以用于控制器的初始化方法 使用方法很简单,举例如下: ~~~ <?php namespace app\index\controller; use app\index\model\User; use think\Controller; class Index extends Controller { public function index() { $user = new User; //实例化User对象 $result = $user->save($data); if($result){ //设置成功后跳转页面的地址,默认的返回页面是$_SERVER['HTTP_REFERER'] $this->success('新增成功', 'User/list'); } else { //错误页面的默认跳转页面是返回前一页,通常不需要设置 $this->error('新增失败'); } } } ~~~ 跳转地址是可选的,success方法的默认跳转地址是`$_SERVER["HTTP_REFERER"]`,error方法的默认跳转地址是`javascript:history.back(-1);`。 默认的等待时间都是3秒 success和error方法都可以对应的模板,默认设置是两个方法对应的模板都是: ~~~ THINK_PATH . 'tpl/dispatch_jump.tpl' ~~~ 我们可以改变默认的模板区分success和error方法: ~~~ //默认错误跳转对应的模板文件 'dispatch_error_tmpl' => APP_PATH . 'tpl/dispatch_jump.tpl', //默认成功跳转对应的模板文件 'dispatch_success_tmpl' => APP_PATH . 'tpl/dispatch_jump.tpl', ~~~ 也可以使用项目内部的模板文件 ~~~ //默认错误跳转对应的模板文件 'dispatch_error_tmpl' => 'public/error', //默认成功跳转对应的模板文件 'dispatch_success_tmpl' => 'public/success', ~~~ 模板文件可以使用模板标签,并且可以使用下面的模板变量: |变量| 含义| |--|--| |$data |要返回的数据| |$msg |页面提示信息| |$code |返回的code| |$wait |跳转等待时间 单位为秒| |$url |跳转页面地址| `error方法`会自动判断当前请求是否属于`Ajax请求`,如果属于`Ajax请求`则会自动转换为`default_ajax_return`配置的格式返回信息。 `success`在`Ajax请求`下不返回信息,需要开发者自行处理。