`
miss_安
  • 浏览: 20267 次
文章分类
社区版块
存档分类
最新评论

PHP实现时间轴函数(个性化时间)

阅读更多
我们在论坛发帖、发表评论、或者是使用QQ空间发布日志、微博发表言论时,会看到发表的内容后的时间显示为“刚刚”、“5分钟前”、“昨天10:23”等,而不是直接显示具体日期和时间。
本文将介绍如何实现基于时间轴的时间的转换。
首先我们要明白时间的几个函数:
time():返回当前的 Unix 时间戳
date():格式化一个本地时间/日期。
应用举例:
date("Y-m-d H:i:s",time());
格式化当前时间,输出:2010-10-11 05:27:35
strtotime():将任何英文文本的日期时间描述解析为 Unix 时间戳。
应用举例:
echo strtotime("+1 day"), "\n";
输出1天前的时间戳:1286861475
date_default_timezone_set():设定要用的默认时区。
一般我们设置北京时间:date_default_timezone_set("PRC");
理解上面几个函数后我们来写时间轴函数:
该函数的原理就是将系统当前时间与目标时间比较,得到一个差值,再将差值与时间范围(转换成秒)比较,根据其处在时间轴的范围输出不同的结果(如:5分钟前)。为了便于计算,我们将时间都转换成Unix时间戳。
function tranTime($time) {
    $rtime = date("m-d H:i",$time);
    $htime = date("H:i",$time);
    
    $time = time() - $time;

    if ($time < 60) {
        $str = '刚刚';
    }
    elseif ($time < 60 * 60) {
        $min = floor($time/60);
        $str = $min.'分钟前';
    }
    elseif ($time < 60 * 60 * 24) {
        $h = floor($time/(60*60));
        $str = $h.'小时前 '.$htime;
    }
    elseif ($time < 60 * 60 * 24 * 3) {
        $d = floor($time/(60*60*24));
        if($d==1)
           $str = '昨天 '.$rtime;
        else
           $str = '前天 '.$rtime;
    }
    else {
        $str = $rtime;
    }
    return $str;
}
函数tranTime()中的参数$time必须为Unix时间戳,如果不是请先用strtotime()将其转换成Unix时间戳。上面的代码一看就明白了,不用再多述。
调用函数,直接输出:
$times="1286861696 ";
echo tranTime($times);
附件下载地址:http://www.huiyi8.com/sc/24508.html
分享到:
评论

相关推荐

    Oracle BIEE 中的时间维与时间轴函数

    时间轴函数概述 创建时间维的准备工作 创建时间维 使用时间轴函数定义度量值 查询 累计、同比、环比是 BI 项目中常用的分析方法。如果采用关系型数据库,直接通过 SQL 语句进行这样的计算是比较麻烦的。Oracle ...

    jquery实现时间轴

    可以使用Flexbox或Grid布局来实现时间点的对齐和分布。 3. **jQuery初始化**:在页面加载完成后,使用`$(document).ready()`来初始化时间轴功能。这里可以获取所有时间点,并根据初始时间进行定位。 4. **动态更新...

    winform简单实现时间轴

    以上是Winform实现时间轴的基本步骤和考虑因素。由于题目提到的代码可能仅实现了部分功能,你可以根据这个指南逐步完善你的实现,或者参考其他开源项目来获取更多的灵感和代码示例。在实际开发中,记得进行充分的...

    MFC 时间轴的简单实现

    在MFC中实现时间轴,我们需要考虑以下几个关键点: 1. **基础控件选择**:MFC提供了多种控件,如CStatic、CToolBar、CListBox等。对于时间轴,我们可能需要自定义一个控件,继承自CWnd或者CControlBar,以便能绘制...

    C# 自定义控件实现时间轴

    最后,`TimeLine2_src`这个文件名可能是源代码或资源文件的压缩包,其中可能包含了实现时间轴控件的完整代码。解压后,开发者可以通过阅读和学习代码,了解具体的实现细节和技巧。 总之,创建C#自定义时间轴控件是...

    MFC下的时间轴

    本篇文章将详细探讨如何在MFC环境下制作时间轴,以及利用GDI(Graphics Device Interface)和CDC(Canvas Device Context)进行自绘来实现高级功能。 时间轴是一种常见的UI元素,常用于展示一系列事件或进程按照...

    html,js实现时间轴,可播放视频,点击放大图片

    总的来说,实现“html,js实现时间轴,可播放视频,点击放大图片”这一功能,需要结合HTML的结构化能力、JavaScript的动态交互特性,以及CSS的美化和布局技巧。通过精心设计和编码,可以创建出既美观又实用的互动...

    PHP实现时间轴函数代码

    本文将介绍如何实现基于时间轴的时间的转换。 首先我们要明白时间的几个函数: time():返回当前的 Unix 时间戳 date():格式化一个本地时间/日期。 应用举例: 复制代码 代码如下: date(“Y-m-d&nbsp;H:i:s”,time()...

    js实现 横向和纵向时间轴切换幻灯片效果

    时间轴是将事件按照时间顺序进行可视化排列的一种方式,它可以是水平的(横向)也可以是垂直的(纵向)。在我们的案例中,幻灯片将在时间轴上移动,让用户能够浏览不同时间点上的内容。 **一、HTML结构** 创建一个...

    Android时间轴(Timeline)效果的实现代码示例

    本示例将详细解释如何在Android应用中实现一个自定义的时间轴效果。 首先,我们需要创建一个自定义的布局来表示时间轴的样式。时间轴通常由三个主要部分组成:时间点、时间线和时间线上的内容。在XML布局文件中,...

    DevExpress之ChartControl实现时间轴实例

    总结一下,DevExpress ChartControl实现时间轴的关键在于设置`Series`的`ArgumentScaleType`为`ScaleType.DateTime`,指定数据源中的日期字段作为X轴的参数,以及设置X轴的时间测量单位和格式。通过这种方式,我们...

    横向时间轴插件_js_时间轴_

    1. JavaScript源文件:通常以.js为扩展名,包含实现时间轴功能的代码。 2. CSS样式文件:可能以.css为扩展名,用于定义时间轴的外观和布局。 3. HTML模板文件:展示时间轴的页面结构,可能包含JavaScript和CSS的引用...

    简易时间轴demo

    在本示例中,“简易时间轴demo”是一个编程项目,它提供了动态添加和初始化多个时间轴项(items)的功能。让我们深入探讨这个话题,了解如何实现这样的功能以及与之相关的技术点。 首先,时间轴的基本结构通常包含...

    qt绘制时间轴,自由设置时间刻度

    - 在QGraphicsView中重写mouseWheelEvent()函数,处理滚轮事件,实现时间轴的缩放。可以通过改变QGraphicsView的缩放因子来实现放大和缩小的效果。 - 重写mouseMoveEvent()和mouseDragEvent(),使用户可以拖拽时间...

    Android时间轴效果的实现

    本篇文章将详细探讨如何在Android中实现时间轴效果。 首先,我们需要创建一个自定义的View来表示时间轴的基本元素。这个View可能包含一条主轴线(代表时间的流逝),以及沿着轴线上下分布的节点(代表特定时间点的...

    HTML5+CSS3实现的响应式垂直时间轴效果源码

    在提供的源码中,`style.css`和`main.css`是两个CSS文件,它们包含了实现时间轴效果的具体样式规则。可能包含对时间轴线的样式定义,如颜色、粗细、以及时间点的样式,包括形状、大小、颜色等。同时,还可能有过渡和...

    js时间轴插件

    在"js时间轴插件"的简单示例中,你可能包括以下步骤来实现一个基本的时间轴: 1. **引入库**:首先,在HTML文件中引入插件所需的JS和CSS文件,确保正确加载。 2. **创建HTML结构**:在页面上设置一个容器元素,...

    html5实现的时间轴设计工作记录样式效果源码

    这是一款基于html5实现的时间轴设计工作记录样式效果源码,是一款时间考勤表样式插件源码。用户可根据自身需求调整显示的文字、颜色及时间等的样式和数值。使之更具个性化。建议使用火狐或谷歌浏览器查看该源码。...

Global site tag (gtag.js) - Google Analytics