js jq插件 显示中文时间戳 刚刚 N分钟前 N小时前 今天 上午 下午 日期格式化
注:页面需提前引用JQ
; $.fn.extend({
/*
** notes: 获取13位时间戳的简单操作
** new Date('2018-02-01 15:10:00').getTime() // Date类型使用getTime方法
** "/Date(1517469000000)/".substring(6,19) // C#后台返回的DateTime数据
*/
/*
** author:lttr <www.cnblogs.com/GoCircle>
** date:2018-02-01
** 对13位时间戳的扩展显示为【不久前,刚刚,N分钟前,N小时前,N天前,N周前,N月前,N年N月N日】的处理
** eg.
** $(1517469000000).commonTimeStamp(); // 1分钟前
*/
"commonTimeStamp": function () {
let selfTime = ((this.selector || $(this)[0]) + Array(13).join('0')).slice(0, 13) - 0, // 补全为13位 PHP时间戳为10位
oneselfDate = new Date(selfTime),
diffValue = new Date().getTime() - selfTime,
monthC = diffValue / 2592000000,// 月1000 * 60 * 60 * 24 * 30
weekC = diffValue / 604800000, // 周1000 * 60 * 60 * 24 * 7
dayC = diffValue / 86400000, // 天1000 * 60 * 60 * 24
hourC = diffValue / 3600000, // 时1000 * 60 * 60
minC = diffValue / 60000; // 分1000 * 60
return diffValue < 0 ? '不久前' :// 如果本地时间反而小于变量时间
monthC > 12 ? (oneselfDate.getFullYear() + '年' + Array(2 - ('' + oneselfDate.getMonth() + 1).length + 1).join(0) + (oneselfDate.getMonth() + 1) + '月' + Array(2 - ('' + oneselfDate.getDate()).length + 1).join(0) + oneselfDate.getDate() + '日') : // 超过1年,直接显示年月日
monthC >= 1 ? (parseInt(monthC) + '月前') :
weekC >= 1 ? (parseInt(weekC) + '周前') :
dayC >= 1 ? (parseInt(dayC) + '天前') :
hourC >= 1 ? (parseInt(hourC) + '小时前') :
minC >= 1 ? (parseInt(minC) + '分钟前') : '刚刚';
},
/*
** author:lttr <www.cnblogs.com/GoCircle>
** date:2018-10-22
** 对13位时间戳的扩展显示为【今天 上午N:N,昨天 上午N:N,上午N:N】的处理
** eg.
** $(1517469000000).specificTimeStamp(); // 下午15:10
*/
"specificTimeStamp": function () {
let oneselfTime = new Date('2018-10-21 00:00:00').getTime(), // 补全为13位 PHP时间戳为10位
parTime = new Date(oneselfTime),
diffDay = parseInt((new Date().getTime() - oneselfTime) / 86400000);// 天1000 * 60 * 60 * 24
return (diffDay == 1 ? "昨天 " : diffDay == 0 ? "今天 " : "") +
((parTime.getHours() / 12 > 1 ? "下午" : "上午") +
Array(2 - ('' + parTime.getHours()).length + 1).join(0) + parTime.getHours() + ":" +
Array(2 - ('' + parTime.getMinutes()).length + 1).join(0) + parTime.getMinutes());
},
/*
** author:lttr <www.cnblogs.com/GoCircle>
** date:2018-02-01
** 对13位时间戳的扩展,将时间转化为指定格式的String
** 年(y)可以用 1-4 个占位符,毫秒(S)只能用 1 个占位符(是 1-3 位的数字)
** 月(M)、日(d)、小时(h)、分(m)、秒(s)、季度(q) 可以用 1-2 个占位符
** eg.
** $(1517469000000).timeFormat("yyyy-MM-dd hh:mm:ss.f"); // 2018-02-01 15:10:00.0
*/
"timeFormat": function (fmt) {
let selfTime = new Date(((this.selector || $(this)[0]) + Array(13).join('0')).slice(0, 13) - 0), // 补全为13位 PHP时间戳为10位
o = {
"q+": Math.floor((selfTime.getMonth() + 3) / 3), //季度
"M+": selfTime.getMonth() + 1, //月份
"d+": selfTime.getDate(), //日
"h+": selfTime.getHours(), //小时
"m+": selfTime.getMinutes(), //分
"s+": selfTime.getSeconds(), //秒
"f": selfTime.getMilliseconds() //毫秒
};
if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (selfTime.getFullYear() + "").substr(4 - RegExp.$1.length));
for (let k in o)
if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
return fmt;
}
});
js jq插件 显示中文时间戳 刚刚 N分钟前 N小时前 今天 上午 下午 日期格式化的更多相关文章
- js前台页面显示中文,后台存对应的value值实现
field: 'rightType', title: '权益类型', //width: 100, align: 'left', valign: 'top', sortable: true, forma ...
- php根据时间显示刚刚,几分钟前,几小时前的实现代码
发布时间距现在的时间 function tranTime($time) { $rtime = date("m-d H:i", $time); $htime = date(" ...
- js 转化为几天前,几小时前,几分钟前...
转换标准时间为时间戳: function getDateTimeStamp(dateStr){ return Date.parse(dateStr.replace(/-/gi,"/" ...
- JS 时间转化为几分钟前 几小时前 几天前
背景:最近公司要做动态列表,类似于微信朋友圈.动态创建时间就需要显示为 刚刚.几分钟前.几小时前.几天前.2018-05-15,这样的形式. 代码如下 var minute = 1000 * 60; ...
- js时间对比-转化为几天前,几小时前,几分钟前
function getDateDiff(dateTimeStamp){ var minute = 1000 * 60; var hour = minute * 60; var day = hour ...
- 用javascript写一个显示时间差 几分钟前 几小时前 几天前 几周前 大于一个月显示日期
window.onload = function(){ var show_times = $(".times span"); for(var i=0;i<show_times ...
- ****timeago.js插件:jquery实现几分钟前、几小时前、几天前等时间差显示效果的代码实例
前端 时间个性化 插件 jquery.timeago.js 关键词 : 时间格式化 刚刚 N分钟前 N小时前 N天前 N月前 N年前 MM-dd hh:mm 或者 yyyy-MM-dd 前端: & ...
- PHP比较全的友好的时间显示,比如‘刚刚’,'几秒前'等
分享一个php友好的比较完成的时间格式化函数,包括‘刚刚’,'几秒之前',‘几分钟前’,'几小时前',几天前,几周前,几个月前等.调用方式很简单,是从ThinkSNS 里面拿出来的. /** * 友好 ...
- javascript Date 日期格式化 formatDate, require.js 模块 支持全局js引入 / amd方式加载
* 引入AMD加载方式: require.js CDN https://cdn.bootcss.com/require.js/2.3.5/require.js * 创建模块文件./js/util/d ...
随机推荐
- linux下安装多个jdk版本的切换问题
下载地址: https://www.azul.com/downloads/zulu/ 解压: [root@localhost java]# tar -zxvf /usr/java/zulu8.38.0 ...
- 访问方式由http改为https curl:(51)
系统访问由http变为https,先申请了CA证书,然后win下浏览器访问时没问题的,但是linux下通过curl的方式访问就报错: curl:(51) SSLcertificate subject ...
- 软工网络15团队作业4——Alpha阶段敏捷冲刺-1
各个成员在 Alpha 阶段认领的任务 成员 Alpha 阶段认领的任务 肖世松 编写界面设计代码 杨泽斌 服务器连接与配置 叶文柠 数据库连接与配置 谢庆圆 编写功能板块代码 林伟航 编写功能板块代 ...
- 统一日志系统 Log4Net/ExceptionLess
一. 写在前面 本文Log4Net介绍了基础的方式,大数据量生产环境不能使用,中等日志量请日志单库. 希望爱技术的你不要错过exceptionless和ELK 第四节开始简单配置大牛们推荐的了Ex ...
- TDDL剖析
前言 在开始讲解淘宝的TDDL(Taobao Distribute Data Layer)技术之前,请允许笔者先吐槽一番.首先要开喷的是淘宝的社区支持做的无比的烂,TaoCode开源社区上面,几乎从来 ...
- codeforces 985 E. Pencils and Boxes (dp 树状数组)
E. Pencils and Boxes time limit per test 2 seconds memory limit per test 256 megabytes input standar ...
- 使用for循环遍历数组元素
循环可以将代码块执行指定的次数.如果您希望一遍又一遍地运行相同的代码,并且每次的值都不同,那么使用循环是很方便的.迭代语句又叫循环语句. JavaScript 支持不同类型的循环: for - 循环代 ...
- SVG总结小知识
SVG:可缩放矢量图形.全称是:Scalable Vector Graphics SVG使用 XML 格式定义图像. SVG是使用 XML 来描述(二维图形和绘图)程序的语言. SVG是W3C ...
- BZOJ4873 [Shoi2017]寿司餐厅 【最大权闭合子图】
题目链接 BZOJ4873 题解 题意很鬼畜,就可以考虑网络流[雾] 然后就会发现这是一个裸的最大权闭合子图 就是注意要离散化一下代号 #include<algorithm> #inclu ...
- oracle行转列函数WMSYS.WM_CONCAT 用法
1.通过 10g 所提供的 WMSYS.WM_CONCAT 函数即可以完成 行转列的效果 select group_code, wm_concat(display_title) from DR_OPM ...