Simple Calendar in JavaScript

In this tutorial, we are going to create Simple Calendar in JavaScript. This simple work creates using JavaScript and HTML. The users enable to navigate the calendar by his/her choice of month. Using a drop down menu to select what they want to display or show in the web page. Visit the Live Demo, kindly click the button below. We are going to construct the Markup for the drop down function to choose the desired month to display in the web page. In the source code below, shows all the list of a month in the drop down, then one textbox for the year, and a button to execute.
  1. <form name="calControl" onSubmit="return false;" method="post">
  2.    <table cellpadding="0" cellspacing="0" border="0">
  3.    <tr>
  4.       <td colspan="7">
  5.          <select class="month_style" name="month" onChange="selectdate()">
  6.             <option>January</option>
  7.             <option>February</option>
  8.             <option>March</option>
  9.             <option>April</option>
  10.             <option>May</option>
  11.             <option>June</option>
  12.             <option>July</option>
  13.             <option>August</option>
  14.             <option>September</option>
  15.             <option>October</option>
  16.             <option>November</option>
  17.             <option>December</option>
  18.          </select>
  19.          <input type="text" class="year_style" name="year"  size="4" maxlength="4">
  20.          <input type="button" class="build_style" name="Go" value="Find . . ." onClick="selectDate()">
  21.       </td>
  22.    </tr>
  23. </form>
And, we have to code for the controls in a calendar. It contains a next and previous button. Take a look a simple source code below.
  1. <form name="calButtons" method="post">
  2.    <tr>
  3.       <td><textarea font="Courier" class="area_style" name="calPage" WRAP="no" rows="8" cols="22" disabled></textarea></td>
  4.    <tr>
  5.       <td>
  6.          <input type="button" class="btn_nav" name="previousYear" value=" <<  "  onClick="setPreviousYear()">
  7.          <input type="button" class="btn_nav" name="previousYear" value="  <  "  onClick="setPreviousMonth()">
  8.          <input type="button" class="btn_nav" name="previousYear" value="Today"  onClick="setToday()">
  9.          <input type="button" class="btn_nav" name="previousYear" value="  >  "  onClick="setNextMonth()">
  10.          <input type="button" class="btn_nav" name="previousYear" value="  >> "  onClick="setNextYear()">
  11.       </td>
  12.    </tr>
  13.    </tr>
  14.    </table>
  15. </form>
This is the script where we can set up the Year, Month, Day, and Date Today. Look the script below.
  1. function setToday() {
  2.     var now = new Date();
  3.     var day = now.getDate();
  4.     var month = now.getMonth();
  5.     var year = now.getYear();
  6.     if (year < 2000)
  7.         year = year + 1900;
  8.     this.focusDay = day;
  9.     document.calControl.month.selectedIndex = month;
  10.     document.calControl.year.value = year;
  11.     displayCalendar(month, year);
  12. }
Use this script to select Month in the web page using a select tag.
  1. function selectDate() {
  2. var year  = document.calControl.year.value;
  3. if (isFourDigitYear(year)) {
  4. var day   = 0;
  5. var month = document.calControl.month.selectedIndex;
  6. displayCalendar(month, year);
  7.     }
  8. }
And, this script helps us to navigate the calendar whether you can Next or Previous in the Month or Year.
  1. function setPreviousYear() {
  2.     var year = document.calControl.year.value;
  3.     if (isFourDigitYear(year)) {
  4.         var day = 0;
  5.         var month = document.calControl.month.selectedIndex;
  6.         year--;
  7.         document.calControl.year.value = year;
  8.         displayCalendar(month, year);
  9.     }
  10. }
  11.  
  12. function setPreviousMonth() {
  13.     var year = document.calControl.year.value;
  14.     if (isFourDigitYear(year)) {
  15.         var day = 0;
  16.         var month = document.calControl.month.selectedIndex;
  17.         if (month == 0) {
  18.             month = 11;
  19.             if (year > 1000) {
  20.                 year--;
  21.                 document.calControl.year.value = year;
  22.             }
  23.         } else {
  24.             month--;
  25.         }
  26.         document.calControl.month.selectedIndex = month;
  27.         displayCalendar(month, year);
  28.     }
  29. }
  30.  
  31. function setNextMonth() {
  32.     var year = document.calControl.year.value;
  33.     if (isFourDigitYear(year)) {
  34.         var day = 0;
  35.         var month = document.calControl.month.selectedIndex;
  36.         if (month == 11) {
  37.             month = 0;
  38.             year++;
  39.             document.calControl.year.value = year;
  40.         } else {
  41.             month++;
  42.         }
  43.         document.calControl.month.selectedIndex = month;
  44.         displayCalendar(month, year);
  45.     }
  46. }
  47.  
  48. function setNextYear() {
  49.     var year = document.calControl.year.value;
  50.     if (isFourDigitYear(year)) {
  51.         var day = 0;
  52.         var month = document.calControl.month.selectedIndex;
  53.         year++;
  54.         document.calControl.year.value = year;
  55.         displayCalendar(month, year);
  56.     }
  57. }

Output

Result That's it, you have a calendar after compiling all the source code above. For the full source code, kindly download below. Thank you.

Add new comment