ios移动端,js时间操作getTime(),getFullYear()等返回显示NaN的解决

在做移动端时间转化为时间戳时,遇到了一个问题,安卓手机上访问时,能拿到时间戳,从而正确转换时间,而在iOS上缺不能正常显示,显示的时间为:NaN-NaN1-NaN 

new Date("2019-04-12 17:30:00".replace(/-/g,'/')).getTime();  // 解决了问题!!

当然getFullYear() ,getMonth(),getDate()需要replace

/**
 * 格式化时间
 * @param {String} str
 * @returns 格式化后的时间
 */
export const TimeData = (str) => {
  if (!str) return ''
  var date = new Date(str.replace(/-/g, '/'))
  var time = new Date().getTime() - date.getTime() // 现在的时间-传入的时间 = 相差的时间(单位 = 毫秒
  if (time < 0) {
    return ''
  } else if ((time / 1000 < 30)) {
    return '刚刚'
  } else if (time / 1000 < 60) {
    return parseInt((time / 1000)) + '秒前'
  } else if ((time / 60000) < 60) {
    return parseInt((time / 60000)) + '分钟前'
  } else if ((time / 3600000) < 24) {
    return parseInt(time / 3600000) + '小时前'
  } else if ((time / 86400000) < 31) {
    return parseInt(time / 86400000) + '天前'
  } else if ((time / 2592000000) < 12) {
    return parseInt(time / 2592000000) + '月前'
  } else {
    return parseInt(time / 31536000000) + '年前'
  }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
iOS移动端时间格式为yyyy-MM-dd时计算其毫秒值会返回NaN的问题可以通过将时间格式转为yyyy/MM/dd来解决。具体做法是使用.replace()函数将日期字符串中的"-"替换为"/",然后再将转换后的日期字符串通过new Date()获取其毫秒值。例如,可以将日期字符串'2021-05-20 18:00:00'转换为'2021/05/20 18:00:00',然后再使用new Date('2021/05/20 18:00:00').getTime()来获取其毫秒值。 另外,还有一种解决方法是将日期格式设置为format="yyyy/MM/dd HH:mm:ss",避免使用format="yyyy-MM-dd HH:mm:ss"的格式,因为在iOS上使用后者的格式会导致返回NaN的问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [解决IOS移动端 格式为yyyy-MM-dd时计算其毫秒值会返回NaN](https://blog.csdn.net/qq_44806249/article/details/124802374)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [【IOS时间格式 NaN 问题解决](https://blog.csdn.net/weixin_43900414/article/details/130523881)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [java后台解析苹果的P12安装证书类封装](https://download.csdn.net/download/qq_42684707/88279835)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值