web-dev-qa-db-ja.com

2つの日付内のランダムな日付の配列を生成するエレガントな方法

2か月を表示する日付ピッカーがあり、表示されている各月に3つの日付をランダムに選択したい

  $('.date').datepicker({
    minDate: new Date(),
    dateFormat: 'DD, MM, d, yy',
    constrainInput: true,
    beforeShowDay: processDates,
    numberOfMonths: 2,
    showButtonPanel: true,
    showOn: "button",
    buttonImage: "images/calendar_icon.jpg",
    buttonImageOnly: true    
  });

これが私の計算です

var now = new Date();
var nowTime = parseInt(now.getTime()/1000);
var randomDateSet = {};

function getRandomSet(y,m) {
  var monthIndex = "m"+y+""+m; // m20121 for Jan
  if (randomDateSet[monthIndex]) return randomDateSet[monthIndex];
  // generate here
.
. - I need this part
.
  return randomDateSet[monthIndex];
}

function processDay(date) { // this is calculated for each day so we need a singleton for the array
  var dateTime = parseInt(date.getTime()/1000);
  if (dateTime <= (nowTime-86400)) {
    return [false]; // earlier than today
  }
  var m = date.getMonth(), d = date.getDate(), y = date.getFullYear();
  var randomDates = getRandomSet(y,m);

  for (i = 0; i < randomDates.length; i++) {
    if($.inArray((m+1) + '-' + d + '-' + y,randomDates) != -1 || new Date() > date) {
      return [true,"highlight","Some message"];
    }
  }
  return [true,"normal"]; // ordinary day
}
68
mplungjan

たぶん私は何かを見逃していますが、これではありませんか?

function randomDate(start, end) {
    return new Date(start.getTime() + Math.random() * (end.getTime() - start.getTime()));
}

randomDate(new Date(2012, 0, 1), new Date())
212
new Date(+(new Date()) - Math.floor(Math.random()*10000000000))
14
Demven Weir

Moment.js && @ Demven Weir's answerを使用して、「1975/02/03」のような文字列値を取得します。

moment(new Date(+(new Date()) - Math.floor(Math.random()*10000000000)))
.format('MM/DD/YYYY');

注:生成される年のスパンを増やすために、一度にゼロを追加し続けます。

1
SoEzPz

境界日付を整数(Date.getTime())に変換し、Math.random()を使用して、指定された境界内でランダムな日付を生成できます。次に、Date.setTime()を使用してDateオブジェクトに戻ります。

1
bububaba