thinkphp5 三種重定向(跳轉)

頁面跳轉

在應用開發中,常常會遇到一些帶有提示信息的跳轉頁面,例如操做成功或者操做錯誤頁面,而且自動跳轉到另一個目標頁面。系統的\think\Controller類內置了兩個跳轉方法successerror,用於頁面跳轉提示。javascript

使用方法很簡單,舉例以下:php

namespace app\index\controller; use think\Controller; use app\index\model\User; 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);java

默認的等待時間都是3秒ajax

successerror方法均可以對應的模板,默認的設置是兩個方法對應的模板都是:thinkphp

THINK_PATH . 'tpl/dispatch_jump.tpl' 

咱們能夠改變默認的模板:session

//默認錯誤跳轉對應的模板文件 'dispatch_error_tmpl' => APP_PATH . 'tpl/dispatch_jump.tpl', //默認成功跳轉對應的模板文件 'dispatch_success_tmpl' => APP_PATH . 'tpl/dispatch_jump.tpl', 

也能夠使用項目內部的模板文件app

//默認錯誤跳轉對應的模板文件 'dispatch_error_tmpl' => 'public/error', //默認成功跳轉對應的模板文件 'dispatch_success_tmpl' => 'public/success', 

模板文件能夠使用模板標籤,而且能夠使用下面的模板變量:函數

變量 含義
$data 要返回的數據
$msg 頁面提示信息
$code 返回的code
$wait 跳轉等待時間 單位爲秒
$url 跳轉頁面地址

error方法會自動判斷當前請求是否屬於Ajax請求,若是屬於Ajax請求則會自動轉換爲default_ajax_return配置的格式返回信息。 success在Ajax請求下不返回信息,須要開發者自行處理。thinkphp5

重定向

\think\Controller類的redirect方法能夠實現頁面的重定向功能。ui

redirect方法的參數用法和Url::build方法的用法一致(參考URL生成部分),例如:

//重定向到News模塊的Category操做 $this->redirect('News/category', ['cate_id' => 2]); 

上面的用法是跳轉到News模塊的category操做,重定向後會改變當前的URL地址。

或者直接重定向到一個指定的外部URL地址,例如:

//重定向到指定的URL地址 而且使用302 $this->redirect('http://thinkphp.cn/blog/2',302); 

能夠在重定向的時候經過session閃存數據傳值,例如

$this->redirect('News/category', ['cate_id' => 2], 302, ['data' => 'hello']); 

使用redirect助手函數還能夠實現更多的功能,例如能夠記住當前的URL後跳轉

redirect('News/category')->remember(); 

須要跳轉到上次記住的URL的時候使用:

redirect()->restore();
相關文章
相關標籤/搜索