Показать сообщение отдельно
  #20 (permalink)  
Старый 26.09.2019, 01:05
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,135

m~r.Nemo,
<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title>Calendar</title>
  </head>
  <body>
    <style>

      .day {
        border: 1px solid #ccc;
        width: 30px;
        line-height: 30px;
        text-align: center;
        margin: 1px;
        background-color: #B0C4DE;
      }
      .month {
          width: 238px;
          height: 238px;
          margin: 30px auto;
          border: 1px solid #ccc;
      }

      .month tr:nth-child(n + 7) td.day{
         background-color:  #FF85C6;
      }
      .month tr:nth-child(1) th{
         text-align: center;
      }

    </style>
    <table class="month"></table>
    <script>
      var calendar = {
        update: function(year, month) {
          this.year = year;
          this.month = [
        'Январь', 'Февраль', 'Март', 'Апрель', 'Май', 'Июнь',
        'Июль', 'Август', 'Сентябрь', 'Октябрь', 'Ноябрь', 'Декабрь'
          ][month];
          var stepDay = new Date(year, month, 1);
          stepDay.setDate(stepDay.getDate() - ((stepDay.getDay()||7) - 1));
          var lastDay = new Date(stepDay);
          lastDay.setDate(lastDay.getDate() + 41);
          while (stepDay <= lastDay) {
            this.days.push(stepDay.getDate());
            stepDay.setHours(24);
          }
        },
        render: function() {
          var html = ['<tr>','<tr>','<tr>','<tr>','<tr>','<tr>','<tr>'];
          for (var i = 0; i < this.days.length; i++) {
            html[i % 7] += '<td class="day">' + this.days[i] ;
          }
          var title = '<tr><th colspan=7>' + this.year + ', ' + this.month;
          this.element.innerHTML = title + html.join('');
        }
      };
      var today = new Date(),
        thisYear = today.getFullYear(),
        thisMonth = today.getMonth();
      calendar.days = ['Пн', 'Вт', 'Ср', 'Чт', 'Пт', 'Сб', 'Вс'];

      calendar.element = document.querySelector('.month');
      calendar.update(thisYear, thisMonth);
      calendar.render();
    </script>
  </body>
</html>
Ответить с цитированием