首页 » 开源/框架 » ThinkPHP » 正文

[TP笔记]ThinkPHP自定义错误页面、成功页面及异常页面

看了前面分享的一篇《什么是真正的程序员?》,觉得自己离这个目标还差的很远,所以要抓紧朝着这个方向前进。作为一名PHP小码农,掌握一种框架是必须的。所以今天开始我们就从国产PHP框架 ThinkPHP 开始学起~

为什么会选择 ThinkPHP 呢?首先,作为一款国产PHP框架,文档肯定比国外那些框架要丰富的多,而且容易看懂;其次,ThinkPHP已经发展了七八年的时间了,相对来说已经比较成熟了;当然,最重要的是它比较轻量级,相对其他的框架来说比较容易上手,所以就选择了ThinkPHP。

好了话不多说,下面分享第一篇笔记~

ThinkPHP 作为一款轻量级PHP开发框架,它为我们提供了自带的错误页面、异常页面等信息提示页面,比如下面的代码会出现这样的提示:

$this->error('验证码错误!');

ThinkPHPError页面

我们可以看到,自带的页面并不美观,所以我们需要自定义这些页面,ThinkPHP 为我们提供了自定义提示页面这样一种功能。

在配置文件中添加如下配置信息:

/* 错误页面模板 */
'TMPL_ACTION_ERROR'     =>  MODULE_PATH.'View/Public/error.html', // 默认错误跳转对应的模板文件
'TMPL_ACTION_SUCCESS'   =>  MODULE_PATH.'View/Public/success.html', // 默认成功跳转对应的模板文件
'TMPL_EXCEPTION_FILE'   =>  MODULE_PATH.'View/Public/exception.html',// 异常页面的模板文件

把这段配置信息放入到当前模型的 /Conf/config.php 中,然后在当前模型的 View 目录下创建 Public 文件夹,并在里面自定义 error.html success.html 及 exception.html 即可。

下面是一个简单的错误页面模板:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>跳转提示</title>
<style type="text/css">
*{ padding: 0; margin: 0; }
body{ background: #290C0C; font-family: '微软雅黑'; color: #fff; font-size: 16px; }
.system-message{ padding: 24px 48px; }
.system-message h1{ font-size: 80px; font-weight: normal; line-height: 120px; margin-bottom: 12px }
.system-message .jump{ padding-top: 10px;margin-bottom:20px}
.system-message .jump a{ color: #333;}
.system-message .success,.system-message .error{ line-height: 1.8em; font-size: 36px }
.system-message .detail{ font-size: 12px; line-height: 20px; margin-top: 12px; display:none}
#wait {
    font-size:46px;
}
#btn-stop,#href{
    display: inline-block;
    margin-right: 10px;
    font-size: 16px;
    line-height: 18px;
    text-align: center;
    vertical-align: middle;
    cursor: pointer;
    border: 0 none;
    background-color: #8B0000;
    padding: 10px 20px;
    color: #fff;
    font-weight: bold;
    border-color: transparent;
    text-decoration:none;
}

#btn-stop:hover,#href:hover{
    background-color: #ff0000;
}
</style>
</head>
<body>
<div class="system-message">
<h1>抱歉,出错啦!</h1>
<p class="error"><?php echo($error); ?></p>
<p class="detail"></p>
<p class="jump">
<b id="wait"><?php echo($waitSecond); ?></b> 秒后页面将自动跳转
</p>
<div>
    <a id="href" id="btn-now" href="<?php echo($jumpUrl); ?>">立即跳转</a> 
    <button id="btn-stop" type="button" onclick="stop()">停止跳转</button> 
    <a id="href" id="btn-now" href="<?php echo(U('Public/logout')); ?>">重新登录</a> 
</div>
</div>
<script type="text/javascript">
(function(){
 var wait = document.getElementById('wait'),href = document.getElementById('href').href;
 var interval = setInterval(function(){
     	var time = --wait.innerHTML;
     	if(time <= 0) {
     		location.href = href;
     		clearInterval(interval);
     	};
     }, 1000);
  window.stop = function (){
         console.log(111);
            clearInterval(interval);
 }
 })();
</script>
</body>
</html>

我们把上面的代码放到自定义 error.html 页面中,然后再看最开始的错误提示页面就会变成下面这样:

tp_error_2

赞 (79) or

本文共 14 个回复

  • 梦轩丽人 2014/06/20 17:53

    看了博主这篇文章我才知道PHP还有框架之说,百度了一下PHP框架竟然还分有N种,我一直以为PHP就是PHP呢,因为我也是接触WordPress后才接触PHP的,每次修改东西都只是修改一个PHP页面,真的是坐井观天了。

    • Specs 2014/06/20 17:56

      @ 梦轩丽人 PHP的框架很多了~~现在不学一个框架找工作的时候都不好找 :eek:

      • 梦轩丽人 2014/06/20 17:59

        @ Specs 如果作为一个程序猿,还是需要掌握精通一个框架的!

  • 屠龙 2014/06/21 14:45

    原来php这么多的知识,一串连着一串的 :evil:

  • 网赚论坛 2014/12/22 10:29

    有很多看不太懂呢

  • 小片头 2016/02/17 16:52

    感觉很不错挺有用的,收藏先!

  • 小片头 2016/02/29 15:56

    得等到

  • aini 2016/03/15 10:02

    请问这个几秒后 秒后页面将自动跳转这个$waitSecond哪里来的

    • Specs 2016/03/15 13:10

      @ aini PHP 传过去的

    • 梳丶 2016/03/17 15:44

      @ aini 框架自带的,不用管。:)当然,想深入学习也可以,要努力才行啊。:(

  • 梳丶 2016/03/19 10:57

    可是自定义页面只能内联CSS,并且无法连接图片,怎么办啊? :(谁解决了告诉我一下具体方法吧 :)

  • 这个有意思 2018/05/26 15:07

    这个邮箱有什么作用呢?这个方法不错,谢谢了

发表评论