zoukankan      html  css  js  c++  java
  • 轮流值班逻辑

    /*

    每周一位,轮流值日。
    获取某日轮到谁值日的逻辑如下:

    1、获取某日属于本年的第几周,周的序号从1开始


    2、设周序号为W


    3、值班同事存为数组P,例如:['王建','马清秦','刘俊','覃光焰']


    4、所有值班同事的人数即为数组P的长度,设这个长度为L


    5、令 N = W % L, N = N === 0 ? L : N, 则有: 第N周值班的同事为P[N-1]

    */

    // JavaScript实现
    
    function getWeek (dateTime) {
            let temptTime = dateTime
            //周几
            let weekday = temptTime.getDay() || 7
            //周1+5天=周六
            temptTime.setDate(temptTime.getDate() - weekday + 1 + 5)
            let firstDay = new Date(temptTime.getFullYear(), 0, 1)
            let dayOfWeek = firstDay.getDay()
            let spendDay = 1
            if (dayOfWeek != 0) {
              spendDay = 7 - dayOfWeek + 1
            }
            firstDay = new Date(temptTime.getFullYear(), 0, 1 + spendDay)
            let d = Math.ceil((temptTime.valueOf() - firstDay.valueOf()) / 86400000)
            let result = Math.ceil(d / 7)
            return result + 1
    }
    
    
    
    function whoDuty(str, P){
      var time = new Date(str);
      var W = getWeek(time);
      var L = P.length;
    
      var N = W % L;
    
      N = N == 0 ? L : N;
    
      return P[N-1];
    }
    
    whoDuty("2020/2/28",['A','B','C','D'])
    // PHP实现
    
    function who_is_on_duty()
    {
        $P = [
            '68649639@qq.com',
            '812154952@qq.com',
            '37534901@qq.com',
            '3141235825@qq.com'
        ];
        $W = date('W');
        $L = count($P);
        $N = $W % $L;
        $N = $N === 0 ? $L : $N;
        return $P[$N - 1];
    }
  • 相关阅读:
    Ajax 异步请求返回集合遍历问题
    JS 类数组,字符串,转换成数组的方法
    laravel、TP、YII三个框架的优缺点对比
    纵深防御
    渗透测试小结
    常见的设计模式
    CDN简介
    WAF小介
    分布式事务及其常见的解决方案
    redis主从复制
  • 原文地址:https://www.cnblogs.com/macliu/p/12145800.html
Copyright © 2011-2022 走看看