> 백엔드 개발 > PHP 튜토리얼 > PHP封装的一个支持HTML、JS、PHP重定向的多功能跳转函数_PHP

PHP封装的一个支持HTML、JS、PHP重定向的多功能跳转函数_PHP

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-06-01 11:50:46
원래의
1351명이 탐색했습니다.

PHP 跳转,即重定向浏览器到指定的 URL,是一个很常见的功能。这种功能也有一些细节性的要求,比如等待多少秒以后跳转,用不用JavaScript实现跳转,等等。下面的跳转方法考虑到很多,并参数化,可以用到具体的项目当中。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

<&#63;php  

/**  

 * 重定向浏览器到指定的 URL  

 *  

 * @param string $url 要重定向的 url  

 * @param int $delay 等待多少秒以后跳转  

 * @param bool $js 指示是否返回用于跳转的 JavaScript 代码  

 * @param bool $jsWrapped 指示返回 JavaScript 代码时是否使用 <mce:script type="text/javascript"><!--

 标签进行包装  

 * @param bool $return 指示是否返回生成的 JavaScript 代码  

 */   

function redirect($url, $delay = 0, $js = false, $jsWrapped = true, $return = false)    

{    

  $delay = (int)$delay;    

  if (!$js) {    

    if (headers_sent() || $delay > 0) {    

      echo <<<EOT    

  <html>    

  <head>    

  <meta http-equiv="refresh" content="{$delay};URL={$url}" />    

  </head>    

  </html>    

EOT;    

      exit;    

    } else {    

      header("Location: {$url}");    

      exit;    

    }    

  }    

     

  $out = '';    

  if ($jsWrapped) {    

    $out .= '<script language="JavaScript" type="text/javascript">';    

  }    

  $url = rawurlencode($url);    

  if ($delay > 0) {    

    $out .= "window.setTimeOut(function () { document.location='{$url}'; }, {$delay});";    

  } else {    

    $out .= "document.location='{$url}';";    

  }    

  if ($jsWrapped) {    

    $out .= '

// --></mce:script>';    

  }    

     

  if ($return) {    

    return $out;    

  }    

     

  echo $out;    

  exit;    

}   

&#63;>

로그인 후 복사

관련 라벨:
php
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿