计算两个日期之间的间隔以及判断过期超时的工具类

1.时间戳转化为正常格式时间

function timestampToTime(timestamp) {
        var date = new Date(timestamp * 1000);//时间戳为10位需*1000,时间戳为13位的话不需乘1000
       var Y = date.getFullYear() + '-';
       var M = (date.getMonth()+1 < 10 ? '0'+(date.getMonth()+1) : date.getMonth()+1) + '-';
       var D = (date.getDate() < 10 ? '0'+date.getDate() : date.getDate()) + ' ';
       var h = (date.getHours() < 10 ? '0'+date.getHours() : date.getHours()) + ':';
       var m = (date.getMinutes() < 10 ? '0'+date.getMinutes() : date.getMinutes()) + ':';
       var s = (date.getSeconds() < 10 ? '0'+date.getSeconds() : date.getSeconds());
        return Y+M+D+h+m+s;
    }

2.计算时间

   //
    function  nowInDateBetwen (start,end) {
    //如果时间格式是正确的,那下面这一步转化时间格式就可以不用了
    var dateBegin = new Date(start.replace(/-/g, "/"));//将-转化为/,使用new Date
     var dateEnd = new Date(end.replace(/-/g, "/"));//将-转化为/,使用new Date
      var dateNow = new Date();//获取当前时间
      
    var beginDiff = dateNow.getTime() - dateBegin.getTime();//时间差的毫秒数       
    var beginDayDiff = Math.floor(beginDiff / (24 * 3600 * 1000));//计算出相差天数
          var endDiff = dateEnd.getTime() - dateNow.getTime();//时间差的毫秒数
    var endDayDiff = Math.floor(endDiff / (24 * 3600 * 1000));//计算出相差天数 

    if (endDayDiff < 0) {//已过期
        return 1;
    }
    if (beginDayDiff < 0) {//没到开始时间

        var time =dateBegin.getTime()- dateNow.getTime() ;//时间差的毫秒数 
        var days=Math.floor(time/(24*3600*1000))  
        // console.log(days);
        var leave1=time%(24*3600*1000)    //计算天数后剩余的毫秒数  
         var hours=Math.floor(leave1/(3600*1000))  
       // /   // console.log(hours);
          var leave2=leave1%(3600*1000)        //计算小时数后剩余的毫秒数  
          var minutes=Math.floor(leave2/(60*1000))  
          // console.log(minutes);
         var local =window.localStorage;
         local.setItem("time",""+days+"天"+hours+"小时");
         // alert(" 剩 "+days+"天 "+hours+"小时 "+minutes+" 分钟")  
        return 2;
    }
        var time =dateEnd.getTime()- dateNow.getTime() ;//时间差的毫秒数
        var days=Math.floor(time/(24*3600*1000))
        var leave1=time%(24*3600*1000)    //计算天数后剩余的毫秒数  
         var hours=Math.floor(leave1/(3600*1000))  
          var leave2=leave1%(3600*1000)        //计算小时数后剩余的毫秒数  
          var minutes=Math.floor(leave2/(60*1000))  
         var local =window.localStorage;  
         local.setItem("last_time",""+days+"天"+hours+"小时");
          // alert(" 剩 "+days+"天 "+hours+"小时 "+minutes+" 分钟"结束)  
         return 3;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
是的,Axios 允许我们自定义请求头和超时时间。我们可以在创建 Axios 实例时传递一个配置对象,其中可以包含一个 `headers` 属性和一个 `timeout` 属性。 以下是一个示例,展示了如何自定义请求头和超时时间: ```javascript import axios from 'axios'; // 创建一个 Axios 实例 const instance = axios.create({ baseURL: 'http://api.example.com', timeout: 10000, // 请求超时时间 headers: { 'Content-Type': 'application/json', 'Authorization': 'Bearer xxxxxxxx' // 自定义请求头 } }); // 定义一个请求方法 export function request(method, url, data) { return instance({ method: method, url: url, data: data }); } // GET 请求方法 export function get(url, params) { return request('get', url, { params: params }); } // POST 请求方法 export function post(url, data) { return request('post', url, data); } ``` 在上面的示例中,我们在创建 Axios 实例时,传递了一个配置对象,其中包含了一个 `headers` 属性和一个 `timeout` 属性。我们可以在 `headers` 属性中自定义请求头,在 `timeout` 属性中设置请求超时时间。然后在 `request`、`get`、`post` 方法中使用这个 Axios 实例发送请求。 例如,我们可以在发送请求时,自定义一个 Authorization 请求头: ```javascript import { get } from './axios-utils'; // GET 请求示例 get('/users', { page: 1 }, { headers: { 'Authorization': 'Bearer yyyyyyyy' } }).then(response => { console.log(response.data); }).catch(error => { console.log(error); }); ``` 在上面的示例中,我们在调用 `get` 方法时,传递了一个配置对象,其中包含了一个 `headers` 属性,该属性包含了一个自定义的 Authorization 请求头。这样发送请求时,就会使用这个自定义的请求头。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值