将时间转换为 `刚刚`、`几秒前`、`几分钟前`、`几小时前`、`几天前`、几月前或按照传入格式显示

    const formatPast = (date, type = "default", zeroFillFlag = true) => {
        // 定义countTime变量,用于存储计算后的数据
        let countTime;
        // 获取当前时间戳
        let time = new Date().getTime();
        // 转换传入参数为时间戳
        let afferentTime = new Date(date).getTime();
        // 当前时间戳 - 传入时间戳
        time = Number.parseInt(`${time - afferentTime}`);
        if (time < 10000) {
            // 10秒内
            return "刚刚";
        } else if (time < 60000) {
            // 超过10秒少于1分钟内
            countTime = Math.floor(time / 1000);
            return `${countTime}秒前`;
        } else if (time < 3600000) {
            // 超过1分钟少于1小时
            countTime = Math.floor(time / 60000);
            return `${countTime}分钟前`;
        } else if (time < 86400000) {
            // 超过1小时少于24小时
            countTime = Math.floor(time / 3600000);
            return `${countTime}小时前`;
        } else if (time >= 86400000 && type == "default") {
            // 超过二十四小时(一天)且格式参数为默认"default"
            countTime = Math.floor(time / 86400000);
            //大于等于365天
            if (countTime >= 365) {
                return `${Math.floor(countTime / 365)}年前`;
            }
            //大于等于30天
            if (countTime >= 30) {
                return `${Math.floor(countTime / 30)}个月前`;
            }
            return `${countTime}天前`;
        } else {
            // 一天(24小时)以上且格式不为"default"则按传入格式参数显示不同格式
            // 数字补零
            let Y = new Date(date).getFullYear();
            let M = new Date(date).getMonth() + 1;
            let zeroFillM = M > 9 ? M : "0" + M;
            let D = new Date(date).getDate();
            let zeroFillD = D > 9 ? D : "0" + D;
            // 传入格式为"-" "/" "."
            if (type == "-" || type == "/" || type == ".") {
                return zeroFillFlag
                    ? Y + type + zeroFillM + type + zeroFillD
                    : Y + type + M + type + D;
            }
            // 传入格式为"年月日"
            if (type == "年月日") {
                return zeroFillFlag
                    ? Y + type[0] + zeroFillM + type[1] + zeroFillD + type[2]
                    : Y + type[0] + M + type[1] + D + type[2];
            }
            // 传入格式为"月日"
            if (type == "月日") {
                return zeroFillFlag
                    ? zeroFillM + type[0] + zeroFillD + type[1]
                    : M + type[0] + D + type[1]
            }
            // 传入格式为"年"
            if (type == "年") {
                return Y + type
            }

        }
    };
    console.log(formatPast("2024-1-1 11:11:11")); // 3天前
    console.log(formatPast("2023-11-1 11:11:11")); // 2个月前
    console.log(formatPast("2015-07-10 21:32:01")); // 8年前
    console.log(formatPast("2023-02-01 09:32:01", "-", false)); // 2023-2-1
    console.log(formatPast("2023.12.8 19:32:01", "/")); // 2023/12/08
    console.log(formatPast("2023.12.8 19:32:01", ".")); // 2023.12.08
    console.log(formatPast("2023/5/10 11:32:01", "年月日")); // 2023年05月10日
    console.log(formatPast("2023/6/25 11:32:01", "月日", false)); // 6月25日
    console.log(formatPast("2023/8/08 11:32:01", "年")); // 2023年

  • 8
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用 JavaScript 中的 Date 对象来将时间转换为"几天几时几分几秒"。可以使用 Date 构造函数将时间传入,然后使用 getUTCDate、getUTCHours、getUTCMinutes、getUTCSeconds 方法分别获取天、小时、分钟、秒。代码示例如下: ```js var timestamp = 1623471235; var date = new Date(timestamp * 1000); var days = date.getUTCDate() - 1; var hours = date.getUTCHours(); var minutes = date.getUTCMinutes(); var seconds = date.getUTCSeconds(); console.log(days + "天" + hours + "时" + minutes + "分" + seconds + "秒"); ``` 其中 timestamp 是时间戳。 需要注意的是,JS中的时间戳是毫秒为单位的,所以需要将时间戳乘1000。 ### 回答2: 在JavaScript中,我们可以使用内置的Date对象来将时间转换为"几天几时几分几秒"的形式。 首先,我们需要将时间转换为Date对象。可以使用`new Date(timeStamp)`来实现,其中`timeStamp`是要转换时间戳。 然后,我们可以使用Date对象的方法来获取对应的年、月、日、时、分、秒等信息。例如,`getDate()`获取月份中的日期,`getHours()`获取小时数,以此类推。 接下来,我们可以根据获取到的信息来计算出"几天几时几分几秒"的形式。这可以通过使用除法和取模(%)操作符来实现。 以下是一个示例代码: ```javascript function timeStampToDuration(timeStamp) { var time = new Date(timeStamp); var days = Math.floor(time / (24 * 3600 * 1000)); // 计算天数 var hours = Math.floor((time % (24 * 3600 * 1000)) / (3600 * 1000)); // 计算小时数 var minutes = Math.floor((time % (3600 * 1000)) / (60 * 1000)); // 计算分钟数 var seconds = Math.floor((time % (60 * 1000)) / 1000); // 计算秒数 return days + "天" + hours + "时" + minutes + "分" + seconds + "秒"; } var timeStamp = 1618500640000; // 假设时间戳为此值 console.log(timeStampToDuration(timeStamp)); // 输出: "18天15时30分40秒" ``` 以上代码将时间戳`1618500640000`转换为"18天15时30分40秒"的形式,并将结果输出到控制台。 ### 回答3: JavaScript中可以使用内置的Date对象将时间转换为"几天几时几分几秒"。 我们可以创建一个函数来实现这个转换。首先,我们将时间转换为毫秒数,并将其传递给Date对象。然后,我们可以使用Date对象提供的方法获取相关的时间信息,包括天数、小时数、分钟数和秒数。最后,我们将这些时间信息拼接成所需的格式。 下面是一个示例代码: ```javascript function convertTimestamp(timestamp) { var seconds = Math.floor(timestamp / 1000); var minutes = Math.floor(seconds / 60); var hours = Math.floor(minutes / 60); var days = Math.floor(hours / 24); seconds %= 60; minutes %= 60; hours %= 24; var result = days + "天 " + hours + "小时 " + minutes + "分 " + seconds + "秒"; return result; } var timestamp = 1595446981000; var convertedTime = convertTimestamp(timestamp); console.log(convertedTime); ``` 这样,我们就可以将时间戳`1595446981000`转换为"18天 19小时 16分 21秒"。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值