How To Get Next Seven Days From X And Format In Js
I want to print something like this (a 7-day calendar) but with the ability to start from any date I want. Monday, 1 January 2011 Tuesday, 2 January 2011 Wednesday, 3 January 2011
Solution 1:
This seems to be what you're looking for:
functionGetDates(startDate, daysToAdd) {
    var aryDates = [];
    for (var i = 0; i <= daysToAdd; i++) {
        var currentDate = newDate();
        currentDate.setDate(startDate.getDate() + i);
        aryDates.push(DayAsString(currentDate.getDay()) + ", " + currentDate.getDate() + " " + MonthAsString(currentDate.getMonth()) + " " + currentDate.getFullYear());
    }
    return aryDates;
}
functionMonthAsString(monthIndex) {
    var d = newDate();
    var month = newArray();
    month[0] = "January";
    month[1] = "February";
    month[2] = "March";
    month[3] = "April";
    month[4] = "May";
    month[5] = "June";
    month[6] = "July";
    month[7] = "August";
    month[8] = "September";
    month[9] = "October";
    month[10] = "November";
    month[11] = "December";
    return month[monthIndex];
}
functionDayAsString(dayIndex) {
    var weekdays = newArray(7);
    weekdays[0] = "Sunday";
    weekdays[1] = "Monday";
    weekdays[2] = "Tuesday";
    weekdays[3] = "Wednesday";
    weekdays[4] = "Thursday";
    weekdays[5] = "Friday";
    weekdays[6] = "Saturday";
    return weekdays[dayIndex];
}
var startDate = newDate();
var aryDates = GetDates(startDate, 7);
console.log(aryDates);
Result (as of today):
["Thursday, 5 April 2012",
 "Friday, 6 April 2012", 
 "Saturday, 7 April 2012", 
 "Sunday, 8 April 2012", 
 "Monday, 9 April 2012", 
 "Tuesday, 10 April 2012", 
 "Wednesday, 11 April 2012", 
 "Thursday, 12 April 2012"]
Here's a working fiddle.
Solution 2:
Here is my solution using Moment.js
Next 7 days
let days = [];
let daysRequired = 7for (let i = 1; i <= daysRequired; i++) {
  days.push( moment().add(i, 'days').format('dddd, Do MMMM YYYY') )
}
console.log(days)<scriptsrc="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.18.1/moment.min.js"></script>Just in case if you need previous 7 days
let days = [];
let daysRequired = 7for (let i = daysRequired; i >= 1; i--) {
  days.push( moment().subtract(i, 'days').format('dddd, Do MMMM YYYY') )
}
console.log(days)<scriptsrc="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.18.1/moment.min.js"></script>Solution 3:
An initial date:
var startingDay =newDate(year, month, day);
A whole week from startingDay:
var thisDay = newDate();
for(var i=0; i<7; i++) {
  thisDay.setDate(startingDay.getDate() + i);
  console.log(thisDay.format());
}
The formatting function:
Date.prototype.format = function(){
    var months = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"];        
    var days = ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"];
    return days[this.getDay()]
          +", "
          +this.getDate()
          +" "
          +months[this.getMonth()] 
          +" "
          +this.getFullYear();
};
Solution 4:
var feb22 = newDate(2012, 1, 22);
var feb23 = newDate(feb22.getTime() + 1000*60*60*24);
...and so on
Solution 5:
You can set the variable dateString to whatever you want and in the loop you just increase the day. Then you will get the dates, but I think in a different format.
var dateString = '22 Feb 2012';
var actualDate = newDate(dateString);
var newDate;
for(var i=1; i<=7; i++){
 newDate = newDate(actualDate.getFullYear(), actualDate.getMonth(), actualDate.getDate()+i);
}
Post a Comment for "How To Get Next Seven Days From X And Format In Js"