【首页、通用页调用】让[列表时间]按自己想要的格式化 标签
- Tags: 深喉咙 模板 时间 格式化 , 积分 Counts:1331 次
- 评论这篇文章 »
具体参考样例:<?php echo date('Y-m-d',strtotime($o->dtTime)) ?>
以下为具体解释此标签用法:
1,<?php ?>这个就不解释了。PHP标签必需要加的标识符,就类似于ASP里的<% %>和smarty里的<!-- -->一样。是必需加的。
2,date() 函数 里有两个参数,第一个为你要显示的自定义格式样式,例如'Y-m-d',在这里 "Y" 表示要输出的年格式,"m" 表示要输出的月格式,"d" 表示要输出的日格式,"-" 表示要输出的年月日中间的连接符号,假如你原有数据库存的是 '2009-02-27 16:05:45' ,这个个格式化的结果就是要将你原有的时间格式化显示成类似于 '2009-02-27' 这样的格式,具体关于这个参数里的字母日期表示格式可参考下表里的说明;
第二个参数为具体显示的参数,为具体你要格式化的对像,就是要格式化的内容来源,而且要求必需是时间类型,而不能为字符串类型,这也就有了这个参数的形式是 strtotime($o->dtTime) 的原因,在这里$o->dtTime是你要格式的内容来源,不一定非要是$o->dtTime你也完全可定义自己的来源或直接手动符一个时间格式的字符串值来格式化,只是深喉咙的标签从数据库里读取统一的循环输出用的是$o->dtTime,那外面的 strtotime()函数在这里的主要作用就是将你的来源日期类型强制转换为时间类型的。否则将会报错,所以在这里不可缺少;3,深喉咙标签里的样式文件使用样例:
在这里我以大家最长用也是问的最多的新闻列表的标签样式文件list_2.php里的内容为样例如下
<?php
if(URLREWRITE)
{?>
<!--如果采用URL重写,调用新闻链接地址形式如下:html/company/view_22.html,其中get_menuName()函数获得栏目或频道英语名称。-->
<li><span style="float:right;"><?php echo date('Y-m-d',strtotime($o->dtTime)) ?></span><a href="<?php echo get_root_path() ?>/html/<?php echo get_menuName($o->channelId)?>/view_<?php echo $o->id ?>.html"><?php echo $o->title ?></a></li>
<?php
}
else
{?>
<li><span style="float:right;"><?php echo date('Y-m-d',strtotime($o->dtTime)) ?></span><a href="<?php echo get_root_path()?>/?p=<?php echo $o->channelId ?>&a=view&r=<?php echo $o->id ?>"><?php echo $o->title ?></a></li>
<?php
}
?>
| format 字符 | 说明 | 返回值例子 |
|---|---|---|
| a | 小写的上午和下午值 | am 或 pm |
| A | 大写的上午和下午值 | AM 或 PM |
| B | Swatch Internet 标准时 | 000 到 999 |
| d | 月份中的第几天,有前导零的 2 位数字 | 01 到 31 |
| D | 星期中的第几天,文本表示,3 个字母 | Mon 到 Sun |
| F | 月份,完整的文本格式,例如 January 或者 March | January 到 December |
| g | 小时,12 小时格式,没有前导零 | 1 到 12 |
| G | 小时,24 小时格式,没有前导零 | 0 到 23 |
| h | 小时,12 小时格式,有前导零 | 01 到 12 |
| H | 小时,24 小时格式,有前导零 | 00 到 23 |
| i | 有前导零的分钟数 | 00 到 59> |
| I | 是否为夏令时 | 如果是夏令时为 1,否则为 0 |
| j | 月份中的第几天,没有前导零 | 1 到 31 |
| l(“L”的小写字母) | 星期几,完整的文本格式 | Sunday 到 Saturday |
| L | 是否为闰年 | 如果是闰年为 1,否则为 0 |
| m | 数字表示的月份,有前导零 | 01 到 12 |
| M | 三个字母缩写表示的月份 | Jan 到 Dec |
| n | 数字表示的月份,没有前导零 | 1 到 12 |
| O | 与格林威治时间相差的小时数 | 例如:+0200 |
| r | RFC 822 格式的日期 | 例如:Thu, 21 Dec 2000 16:01:07 +0200 |
| s | 秒数,有前导零 | 00 到 59> |
| S | 每月天数后面的英文后缀,2 个字符 | st,nd,rd 或者 th。可以和 j 一起用。 |
| t | 给定月份所应有的天数 | 28 到 31 |
| T | 本机所在的时区 | 例如:EST,MDT(【译者注】在 Windows 下为完整文本格式,例如“Eastern Standard Time”,中文版会显示“中国标准时间”)。 |
| U | 从 Unix 纪元(January 1 1970 00:00:00 GMT)开始至今的秒数 | 参见 time() |
| w | 星期中的第几天,数字表示 | 0(表示星期天)到 6(表示星期六) |
| W | ISO-8601 格式年份中的第几周,每周从星期一开始(PHP 4.1.0 新加的) | 例如:42(当年的第 42 周) |
| Y | 4 位数字完整表示的年份 | 例如:1999 或 2003 |
| y | 2 位数字表示的年份 | 例如:99 或 03 |
| z | 年份中的第几天 | 0 到 366 |
| Z | 时差偏移量的秒数。UTC 西边的时区偏移量总是负的,UTC 东边的时区偏移量总是正的。 | -43200 到 43200 |
