我正在为日期时间对象使用自定义 angular.js 过滤器:
function relativeTimeFilter()
{
return function (dateObj) {
return getRelativeDateTimeString(dateObj);
};
}
function getRelativeDateTimeString(dt)
{
if(!dt) return "undefined ago";
var delta = dt.getSeconds();
if (delta < 0) return "not yet";
if (delta < 1 * 60) return delta == 1 ? "one second ago" : delta + " seconds ago";
if (delta < 2 * 60) return "a minute ago";
if (delta < 45 * 60) return Math.floor(delta/60) + " minutes ago";
if (delta < 90 * 60) return "an hour ago";
if (delta < 24 * (60*60)) return Math.floor(delta/60/60) + " hours ago";
if (delta < 48 * (60*60)) return "yesterday";
if (delta < 30 * (24 * (60*60))) return Math.floor(delta/60/60/24) + " days ago";
if (delta < 12 * (30 * (24 * (60*60))))
{
var months = Math.floor(delta/60/60/24/30);
return (months <= 1) ? "one month ago" : (months + " months ago");
}
else
{
var years = Math.floor(delta/60/60/24/365);
return (years <= 1) ? "one year ago" : (years + " years ago");
}
}
module.filter("relativetime", relativeTimeFilter);
在这一点上,我使用哪个过滤器并不那么重要(我认为)。过滤器接收一个 Datetime 对象。相对时间声明仅有效一秒。含义one second ago
必须在一秒钟后更新2 seconds ago
,以此类推。
当我应用过滤器时,这只发生一次。那么如何定期触发过滤器设备呢?
我尝试了以下方法:
setInterval(function() {$scope.$apply()}, 1000) // placed in controller function
...没有成功。
有任何想法吗?