Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 22.05.2021, 21:06
Аватар для Блондинка
Профессор
Отправить личное сообщение для Блондинка Посмотреть профиль Найти все сообщения от Блондинка
 
Регистрация: 24.02.2019
Сообщений: 806

возможно ли создать таблицу на grid ?
есть див, в который скрипт вставляет много маленьких дивов, количество строк и рядов не всегда постоянная, меняется через элементы формы...

есть два варианта сетки,
1.) 7 строк и динамически меняется количество столбцов
2.) 7 столбов и динамически меняется количество строк

возможно ли на grid в первом варианте создать таблицу с первым столбцом в 20% а остальным столбцам задать одинаковую ширину, и при этом задать всем строкам одинаковую высоту, а во втором варианте создать таблицу с первой строкой в 20% от высоты, остальным строкам задать одинаковую высоту, и при этом задать одинаковую ширину столбов?

как это лучше реализовать? или подскажите как изменить js-код, чтобы генерировалась простая таблица обёрнутая в див...

вот полный код страницы...

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8" />
        <title>calendar-rotate</title>
    <style type="text/css">
      #calendar_rotate {
        border: 1px solid hsl(0,0%,66%);
        padding: 5px;
        display: inline-block;
        width: 373px;
      }
      #navigation_panel { 
        border: 1px solid hsl(0,0%,66%);
        padding: 5px 10px;
        margin: 0 0 5px 0;
        display: inline-block;
        white-space: nowrap;
      }
      .month {
        border: 1px solid hsl(0,0%,66%);
        width: 367px;
        height: 367px;
        padding: 2px;
      }
      .month,
      .month.vert .week_day,
      .day {
        display: inline-block;
      }
      .month.vert .day {
        display: block;
      }
      .day {
        border: 1px solid hsl(0,0%,66%);
        width: 30px;
        line-height: 30px;
        text-align: center;
        padding: 3.5px;
        margin: 2px;
        background-color: hsl(210,100%,90%);
        color: hsl(210,100%,50%);
      }
      .day:nth-child(7n + 6), .day:nth-child(7n + 7) {
        background-color: hsl(348,100%,90%);
        color: hsl(348,100%,50%);
      }
      input { 
        border: 1px solid hsl(0,0%,66%);
        width: 54px;
        display: inline-block;
        text-align: center;
      }
    </style>
    </head>
    <body>
        <div id="calendar_rotate">
        <div id="navigation_panel">
        <select id="month_select"></select> 
        <input id="year_input" type="number" size="4" value=""/> 
        <button id="month_rotate">➙</button>
        </div>
        <div class="month vert"></div>
        <script>
          var calendar = {
            update: function(year, month) {
              this.days.length = 7;
              var stepDay = new Date(year, month, 1);
              stepDay.setDate(stepDay.getDate() + 0 - ((stepDay.getDay() + 6) % 7));
              var lastDay = new Date(year, month + 1, 0);
              lastDay.setDate(lastDay.getDate() + 6 - ((lastDay.getDay() + 6) % 7));
              while (stepDay <= lastDay) {
                this.days.push(stepDay.getDate());
                stepDay.setHours(24);
              }
            },
            render: function() {
              var html = '';
              for (var i = 0, j = 0; i < this.days.length; j = ++i % 7) {
                if (j == 0) html += '<div class="week_day">';
                html += '<div class="day">' + this.days[i] + '</div>';
                if (j == 6) html += '</div>';
              }
              this.element.innerHTML = html;
            },
            toggle: function() {
              this.element.classList.toggle('vert');
            },
          };
          var today = new Date(),
            thisYear = today.getFullYear(),
            thisMonth = today.getMonth();
          calendar.days = ['Пн', 'Вт', 'Ср', 'Чт', 'Пт', 'Сб', 'Вс'];
          selector = document.getElementById('month_select');
          month_list = ['Январь', 'Февраль', 'Март', 'Апрель', ' Май', 'Июнь', 'Июль', 'Август', 'Сентябрь', 'Октябрь', 'Ноябрь', 'Декабрь'];
          for (let i = 0; i < month_list.length; i++){
            selector.options[i] = new Option(month_list[i], i);
          }
          selector.selectedIndex = thisMonth;
          selector.addEventListener('change', load);
          document.getElementById('year_input').addEventListener('change', load);
          calendar.element = document.querySelector('.month');
          document.getElementById('month_rotate').addEventListener('click', function() {
            calendar.toggle();
          });
          function load(){
              let year = document.getElementById('year_input').value;
              let month = selector.selectedIndex;
              calendar.update(year, month);
              calendar.render();
          }
          document.addEventListener("DOMContentLoaded", ()=>{
            document.getElementById('year_input').value = thisYear;
            load();
          });
          
          
        </script>
      </div>
    </body>
</html>

Последний раз редактировалось Блондинка, 22.05.2021 в 21:48.
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Змейка, подсчёт очков Alena_03 Общие вопросы Javascript 1 04.10.2020 14:28
Создать таблицу средствами DOM Neotwalker Events/DOM/Window 4 06.04.2018 13:14
Возможно ли создать скрипт ...? maxfrim Элементы интерфейса 2 31.01.2017 21:09
Подскажите, как создать хэш таблицу (или массив) через цикл osetr Общие вопросы Javascript 6 11.11.2014 12:08
как создать простой grid ? remember_me ExtJS 8 16.07.2013 14:49