8

ユーザーがページにアクセスしたときに、現在の時刻が平日の午前 9 時から午後 5 時 30 分の間にあるかどうかを確認し、jquery/javascript を使用して何かを表示する必要があります。

誰か助けてくれませんか?

ありがとう

4

6 に答える 6

20

これはうまくいけば役立つはずです:

function checkTime() {
    var d = new Date(); // current time
    var hours = d.getHours();
    var mins = d.getMinutes();
    var day = d.getDay();

    return day >= 1
        && day <= 5
        && hours >= 9 
        && (hours < 17 || hours === 17 && mins <= 30);
}
于 2012-01-31T14:37:12.480 に答える
3
var now = new Date();
var dayOfWeek = now.getDay();
if(dayOfWeek > 0 && dayOfWeek < 6){
   //falls on a weekday
   if (now.getHours() > 9 && (now.getHours() < 17 && now.getMinutes() < 30)) {
      //it's in schedule
   }
}
于 2012-01-31T14:37:25.520 に答える
2

現在の時刻を使用すると、次のようなことができます。

var now = new Date(),
    day = now.getDay(),
    hours = now.getHours();

//Check if day is Mon-Fri
if(0 < day < 6) {
  //check between 9am and 5pm
  if(9 <= hours <= 17) {
     if(hours !== 17 || now.getMinutes() <= 30) {
          //your jQuery code here
     }
  }
}
于 2012-01-31T14:37:22.400 に答える
2

時間チェックに2セント追加しただけです...

個人的には、a:b--c:d の範囲内にあるかどうかを確認する方が良いと思います...

// check if h:m is in the range of a:b-c:d
// does not support over-night checking like 23:00-1:00am
function checkTime (h,m,a,b,c,d){
      if (a > c || ((a == c) && (b > d))) {
          // not a valid input
      } else {
           if (h > a && h < c) {
                return true;
           } else if (h == a && m >= b) {
               return true;  
           } else if (h == c && m <= d) {
               return true;
           } else {
                return false;
           }
      }
}

于 2015-10-01T20:46:05.507 に答える