资讯专栏INFORMATION COLUMN

JS 时间字符串和时间戳的相互转换

leonardofed / 3128人阅读

摘要:解决思路将现有的时间字符串先转换为时间戳使用时间戳创建对象,然后利用的方法获取相应的年月日时分秒的值补,并生成所需的时间字符串涉及知识点时间戳概念从年月日时到指定日期字符串的毫秒数。

待解决问题

JS开发遇到了个问题:前端vue的UI组件生成的时间字符串格式是 2018-9-12 9:11:23,而后台只能识别2018-09-12 09:11:23这样的时间字符串,即要将时间字符串格式做转换,数字是个位数的值前面要补0。

解决思路

将现有的时间字符串先转换为时间戳

使用时间戳创建Date对象,然后利用Date的方法获取相应的年、月、日、时、分、秒的值

补0,并生成所需的时间字符串

涉及知识点

时间戳概念:从1970年1月1日0时到指定日期(字符串)的毫秒数。
需利用JS中的Date对象处理日期和时间,用到的方法如下:

Date.parse(timestr): 返回timestr的时间戳
var time = newDate(timestamp)   利用时间戳创建Date对象

JavaScript Date对象的方法可参考:http://www.w3school.com.cn/js...
时间字符串是按需自行组装的,补0就需想办法解决,网上有多种方法。

以下是转换过程:

将时间字符串转换为时间戳
//mytime是待转换时间字符串,格式:"2018-9-12 9:11:23"
dateTmp = mytime.replace(/-/g,"/")   //为了兼容IOS,需先将字符串转换为"2018/9/11 9:11:23"
timestamp = Date.parse(dateTmp)    //返回"2018-9-12 9:11:23"的时间戳
将时间戳转换为所需格式的时间字符串
    var dateFormat = function(timestamp){
        var time = newDate(timestamp)    //先将时间戳转为Date对象,然后才能使用Date的方法
        var year = time.getFullYear(),
            month = time.getMonth() + 1 ,  //月份是从0开始的
            day = time.getDate(),
            hour = time.getHours(),
            minute = time.getMinutes(),
            second = time.getSeconds()
            //add0()方法在后面定义
        return  year+"-"+this.add0(month)+"-"+ this.add0(day)+""+this.add0(hour)+":"+this.add0(minute)+":"+this.add0(second)  
        }
补0的方法add0

补0的方法网上有很多,我使用的方法如下:

        var add0 = function(m){
        return m < 10 ? "0" + m: m
        }
总结

需要了解JavaScript中的Date对象。
要理解字符串转换的思路:即字符串--时间戳---Date对象---攒新的字符串,有思路后做起来就顺理成章了。
本文总结的是一种解决思路,网上有更详细、全面的方法,文章地址如下:
https://blog.csdn.net/FengNex...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/97756.html

相关文章

  • Date对象常用的封装方法及遇到的坑

    摘要:使用中的对象已经很久了但是一直以来都没有将常用的封装函数和遇到的坑记录下来趁着今天有空就记录下来方便自己下次直接使用并提醒自己遇到过那些坑。利用设置日期时从设置当设置为时即上个月的最后一天参考 使用JS中的Date对象已经很久了,但是一直以来都没有将常用的封装函数和遇到的坑记录下来,趁着今天有空,就记录下来,方便自己下次直接使用,并提醒自己遇到过那些坑。如果有哪些地方不对,希望大家能够...

    taowen 评论0 收藏0
  • 关于时间的那些事

    摘要:获取定制时间戳的方法返回数值的单位是毫秒。返回指定日期减去时间间隔后的具体日期返回返回指定日期为全年的第几天日期二将时间戳转为普通日期时间格式当前时间戳将时间戳转为日期时间格式 PHP、JavaScript、MySQL操作时间 关于时间的那些事 PHP篇 PHP中时间操作单位是秒 一、将时间戳转为普通日期格式 //当前时间戳 time(); //当前时间格式 date(Y-m-...

    qqlcbb 评论0 收藏0
  • 关于时间的那些事

    摘要:获取定制时间戳的方法返回数值的单位是毫秒。返回指定日期减去时间间隔后的具体日期返回返回指定日期为全年的第几天日期二将时间戳转为普通日期时间格式当前时间戳将时间戳转为日期时间格式 PHP、JavaScript、MySQL操作时间 关于时间的那些事 PHP篇 PHP中时间操作单位是秒 一、将时间戳转为普通日期格式 //当前时间戳 time(); //当前时间格式 date(Y-m-...

    mzlogin 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<