JS把字符串格式的时间转换成几秒前、几分钟前、几小时前、几天前等格式


Posted in Javascript onJuly 10, 2019

最近在做项目的时候,需要把后台返回的时间转换成几秒前、几分钟前、几小时前、几天前等的格式;后台返回的时间格式为:2015-07-30 09:36:10,需要根据当前的时间与返回的时间进行对比,最后显示成几秒前、几分钟前、几小时前、几天前的形式。

1.由于返回的时间是字符串格式,所以要先转换成时间戳

//字符串转换为时间戳
function getDateTimeStamp (dateStr) {
  return Date.parse(dateStr.replace(/-/gi,"/"));
}

2.将返回的时间戳与当前时间戳进行比较,转换成几秒前、几分钟前、几小时前、几天前的形式。

function getDateDiff (dateStr) {
  var publishTime = getDateTimeStamp(dateStr)/1000,
    d_seconds,
    d_minutes,
    d_hours,
    d_days,
    timeNow = parseInt(new Date().getTime()/1000),
    d,
    date = new Date(publishTime*1000),
    Y = date.getFullYear(),
    M = date.getMonth() + 1,
    D = date.getDate(),
    H = date.getHours(),
    m = date.getMinutes(),
    s = date.getSeconds();
    //小于10的在前面补0
    if (M < 10) {
      M = '0' + M;
    }
    if (D < 10) {
      D = '0' + D;
    }
    if (H < 10) {
      H = '0' + H;
    }
    if (m < 10) {
      m = '0' + m;
    }
    if (s < 10) {
      s = '0' + s;
    }
  d = timeNow - publishTime;
  d_days = parseInt(d/86400);
  d_hours = parseInt(d/3600);
  d_minutes = parseInt(d/60);
  d_seconds = parseInt(d);
  if(d_days > 0 && d_days < 3){
    return d_days + '天前';
  }else if(d_days <= 0 && d_hours > 0){
    return d_hours + '小时前';
  }else if(d_hours <= 0 && d_minutes > 0){
    return d_minutes + '分钟前';
  }else if (d_seconds < 60) {
    if (d_seconds <= 0) {
      return '刚刚发表';
    }else {
      return d_seconds + '秒前';
    }
  }else if (d_days >= 3 && d_days < 30){
    return M + '-' + D + ' ' + H + ':' + m;
  }else if (d_days >= 30) {
    return Y + '-' + M + '-' + D + ' ' + H + ':' + m;
  }
}

3.使用方法:

dateStr:返回的时间字符串,格式如:2015-07-30 09:36:10

// 转换后的结果 
var str = getDateDiff(dateStr);
// 在控制台输出结果 
console.log(str);

总结

以上所述是小编给大家介绍的JS把字符串格式的时间转换成几秒前、几分钟前、几小时前、几天前等格式 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
Jquery ajax传递复杂参数给WebService的实现代码
Aug 08 Javascript
jQuery实现自动与手动切换的滚动新闻特效代码分享
Aug 27 Javascript
深入理解选择框脚本[推荐]
Dec 13 Javascript
自制简易打赏功能的实例
Sep 02 Javascript
JavaScript中递归实现的方法及其区别
Sep 12 Javascript
用Axios Element实现全局的请求loading的方法
Mar 15 Javascript
使用vuex缓存数据并优化自己的vuex-cache
May 30 Javascript
vue移动端实现红包雨效果
Jun 23 Javascript
在vue中更换字体,本地存储字体非引用在线字体库的方法
Sep 28 Javascript
Vue.js 事件修饰符的使用教程
Nov 01 Javascript
如何封装了一个vue移动端下拉加载下一页数据的组件
Jan 06 Javascript
JavaScript实现拖拽盒子效果
Feb 06 Javascript
JS将时间秒转换成天小时分钟秒的字符串
Jul 10 #Javascript
js Array.slice的8种不同用法示例
Jul 10 #Javascript
vue-router二级导航切换路由及高亮显示的实现方法
Jul 10 #Javascript
Vue编程式跳转的实例代码详解
Jul 10 #Javascript
微信小程序在ios下Echarts图表不能滑动的问题解决
Jul 10 #Javascript
Vue事件修饰符native、self示例详解
Jul 09 #Javascript
如何自定义微信小程序tabbar上边框的颜色
Jul 09 #Javascript
You might like
php checkbox 取值详细说明
2010/08/19 PHP
PHP fastcgi模式上传大文件(大约有300多K)报错
2014/09/28 PHP
PHP实现抓取迅雷VIP账号的方法
2015/07/30 PHP
详解yii2实现分库分表的方案与思路
2017/02/03 PHP
Laravel框架中Blade模板的用法示例
2017/08/30 PHP
从ThinkPHP3.2.3过渡到ThinkPHP5.0学习笔记图文详解
2019/04/03 PHP
什么是PHP7中的孤儿进程与僵尸进程
2019/04/14 PHP
Jquery ajaxStart()与ajaxStop()方法(实例讲解)
2013/12/18 Javascript
js的参数有长度限制吗?发现不能超过2083个字符
2014/04/20 Javascript
JQuery跳出each循环的方法
2015/04/16 Javascript
jQuery自动添加表单项的方法
2015/07/13 Javascript
jQuery+HTML5美女瀑布流布局实现方法
2015/09/21 Javascript
JS实现横向与竖向两个选项卡Tab联动的方法
2015/09/27 Javascript
jquery制作图片时钟特效
2020/03/30 Javascript
Bootstrap框架动态生成Web页面文章内目录的方法
2016/05/12 Javascript
JS控制静态页面之间传递参数获取参数并应用的简单实例
2016/08/10 Javascript
纯css下拉菜单 无需js
2016/08/15 Javascript
AngularJs  Understanding Angular Templates
2016/09/02 Javascript
Bootstrap实现各种进度条样式详解
2017/04/13 Javascript
探究一道价值25k的蚂蚁金服异步串行面试题
2020/08/21 Javascript
[06:44]2014DOTA2国际邀请赛-钥匙体育馆开战 开幕式振奋人心
2014/07/19 DOTA
Python中使用PIL库实现图片高斯模糊实例
2015/02/08 Python
浅谈python和C语言混编的几种方式(推荐)
2017/09/27 Python
Python视频爬虫实现下载头条视频功能示例
2018/05/07 Python
python解析含有重复key的json方法
2019/01/22 Python
对python while循环和双重循环的实例详解
2019/08/23 Python
Python 3.8正式发布重要新功能一览
2019/10/17 Python
基于Python实现人脸自动戴口罩系统
2020/02/06 Python
Python使用Pyqt5实现简易浏览器(最新版本测试过)
2020/04/27 Python
追悼会主持词
2014/03/20 职场文书
经济贸易系求职信
2014/08/04 职场文书
2014报到证办理个人委托书
2014/10/08 职场文书
2015新年寄语(一句话)
2014/12/08 职场文书
公司慰问信范文
2015/03/23 职场文书
八年级历史教学反思
2016/02/19 职场文书
pandas取dataframe特定行列的实现方法
2021/05/24 Python