Русскоязычное программирование

Информация о пользователе

Привет, Гость! Войдите или зарегистрируйтесь.


Вы здесь » Русскоязычное программирование » web-разработка » Как сделать таблицу на гридах


Как сделать таблицу на гридах

Сообщений 1 страница 15 из 15

1

Таблица на гридах:

Вариант 1 кода таблицы
Код:
[html]
<style>
#container {
  display: grid;
  grid-gap: 2px;
  grid: repeat(3, 1fr) / auto-flow;
}

#container > div {
  padding: 4px;
  text-align: center;
  background-color: #cee;
}
main{display: inline-grid; padding: 2px; background-color: #666;}
</style>
<main>
<div id="container">
  <div>№ п/п</div>
  <div></div><div></div>
  <div>Назначение элемента</div>
  <div></div><div></div>
  <div>Оригинал</div>
  <div></div><div></div>
  <div>Рекомендуемый аналог</div>
  <div></div><div></div>
  <div>Правило</div>
  <div></div><div></div>
  <div>Пояснение к правилу</div>
  <div></div><div></div>
</div>
</main>
[/html]

Результат:
[html]
<style>
#container {
  display: grid;
  grid-gap: 2px;
  grid: repeat(3, 1fr) / auto-flow;
}

#container > div {
  padding: 4px;
  text-align: center;
  background-color: #cee;
}
main{display: inline-grid; padding: 2px; background-color: #666;}
</style>
<main>
<div id="container">
  <div>№ п/п</div>
  <div></div><div></div>
  <div>Назначение элемента</div>
  <div></div><div></div>
  <div>Оригинал</div>
  <div></div><div></div>
  <div>Рекомендуемый аналог</div>
  <div></div><div></div>
  <div>Правило</div>
  <div></div><div></div>
  <div>Пояснение к правилу</div>
  <div></div><div></div>
</div>
</main>
[/html]

Вариант 2 кода таблицы
Код:
[html]
<style>
#container 
  {padding: 2px;  transform: scale(0.8);
    display: inline-grid;
    grid-gap: 2px;
    grid-template-columns: auto auto auto auto auto auto;
    background-color: #666;
  }

#container > div 
  {padding: 4px;
    text-align: center;
    background-color: #cee;
  }
</style>

<div id="container">
  <div>№ п/п</div><div>Назначение элемента</div><div>Оригинал</div>
  <div>Рекомендуемый аналог</div><div>Правило</div><div>Пояснение к правилу</div>
  <div>1</div>
  <div><svg viewBox="0 0 100 200" width="100" height="200">
    <text x="5" y="20" width="40" height="20">Микроид</text>
  <rect id="нету" x="5" y="50" width="80" height="40" fill="#c52" />
  </svg></div>
  <div></div>
  <div><svg viewBox="0 0 200 200" width="200" height="200">
    <symbol id="penta" width="200" height="200" viewBox="0 0 200 200" >
        <polygon id="star" points="100,0 40,180 195,70 5,70 160,180"
        style="cursor: pointer; fill-rule: nonzero; fill: #aabb00; stroke: none; stroke-width: 1px;"/>
    </symbol>
  <use xlink:href="#penta" x="0" y="0" width="200" height="200"></use>
  <animate xlink:href="#penta" attributeType="XML" attributeName="viewBox"
          from="0 0 200 200" to="0 0 2000 2000" dur="0.8s"
          begin="нету.click" fill="freeze" />
  <animate xlink:href="#penta" attributeType="XML" attributeName="viewBox"
          from="0 0 2000 2000" to="0 0 200 200" dur="0.8s"
          begin="есть.click" fill="freeze" />
</svg></div>
  <div></div>
  <div>Минимизация<br>элементов</div>
  <div>2</div>
  <div><svg viewBox="0 0 100 200" width="100" height="200">
       <text x="5" y="20" width="40" height="20">Мaкроид</text>
       <rect id="есть" x="5" y="50" width="80" height="40" fill="#5c2" />
    </svg></div>
  <div></div><div><svg viewBox="0 0 200 200" width="200" height="200">
    <symbol id="penta" width="200" height="200" viewBox="0 0 200 200" >
        <polygon id="star" points="100,0 40,180 195,70 5,70 160,180"
        style="cursor: pointer; fill-rule: nonzero; fill: #aabb00; stroke: none; stroke-width: 1px;"/>
    </symbol>
  
  <use xlink:href="#penta" x="0" y="0" width="200" height="200"></use>
  <animate xlink:href="#penta" attributeType="XML" attributeName="viewBox"
          from="0 0 200 200" to="0 0 2000 2000" dur="0.8s"
          begin="нету.click" fill="freeze" />
  <animate xlink:href="#penta" attributeType="XML" attributeName="viewBox"
          from="0 0 2000 2000" to="0 0 200 200" dur="0.8s"
          begin="есть.click" fill="freeze" />
</svg></div>
  <div></div>
  <div>Максимизация<br>элементов</div>
</div>
[/html]

Результат:[html]
<style>
#container
  {display: inline-grid;
    padding: 2px; 
    transform: scale(0.8);
    grid-gap: 2px;
    grid-template-columns: auto auto auto auto auto auto;
    background-color: #666;
  }

#container > div
  {padding: 4px;
    text-align: center;
    background-color: #cee;
  }
</style>

<div id="container">
  <div>№ п/п</div><div>Назначение элемента</div><div>Оригинал</div>
  <div>Рекомендуемый аналог</div><div>Правило</div><div>Пояснение к правилу</div>
  <div>1</div>
  <div><svg viewBox="0 0 100 200" width="100" height="200">
    <text x="5" y="20" width="40" height="20">Микроид</text>
  <rect id="нету" x="5" y="50" width="80" height="40" fill="#c52" />
  </svg></div>
  <div></div>
  <div><svg viewBox="0 0 200 200" width="200" height="200">
    <symbol id="penta" width="200" height="200" viewBox="0 0 200 200" >
        <polygon id="star" points="100,0 40,180 195,70 5,70 160,180"
        style="cursor: pointer; fill-rule: nonzero; fill: #aabb00; stroke: none; stroke-width: 1px;"/>
    </symbol>
  <use xlink:href="#penta" x="0" y="0" width="200" height="200"></use>
  <animate xlink:href="#penta" attributeType="XML" attributeName="viewBox"
          from="0 0 200 200" to="0 0 2000 2000" dur="0.8s"
          begin="нету.click" fill="freeze" />
  <animate xlink:href="#penta" attributeType="XML" attributeName="viewBox"
          from="0 0 2000 2000" to="0 0 200 200" dur="0.8s"
          begin="есть.click" fill="freeze" />
</svg></div>
  <div></div>
  <div>Минимизация<br>элементов</div>
  <div>2</div>
  <div><svg viewBox="0 0 100 200" width="100" height="200">
       <text x="5" y="20" width="40" height="20">Мaкроид</text>
       <rect id="есть" x="5" y="50" width="80" height="40" fill="#5c2" />
    </svg></div>
  <div></div><div><svg viewBox="0 0 200 200" width="200" height="200">
    <symbol id="penta" width="200" height="200" viewBox="0 0 200 200" >
        <polygon id="star" points="100,0 40,180 195,70 5,70 160,180"
        style="cursor: pointer; fill-rule: nonzero; fill: #aabb00; stroke: none; stroke-width: 1px;"/>
    </symbol>
 
  <use xlink:href="#penta" x="0" y="0" width="200" height="200"></use>
  <animate xlink:href="#penta" attributeType="XML" attributeName="viewBox"
          from="0 0 200 200" to="0 0 2000 2000" dur="0.8s"
          begin="нету.click" fill="freeze" />
  <animate xlink:href="#penta" attributeType="XML" attributeName="viewBox"
          from="0 0 2000 2000" to="0 0 200 200" dur="0.8s"
          begin="есть.click" fill="freeze" />
</svg></div>
  <div></div>
  <div>Максимизация<br>элементов</div>
</div>
[/html]

0

2

У меня не видны два правых столбца, они не помещаются, не влезают.

http://sh.uploads.ru/t/rFeSx.gif

Отредактировано Лис (2018-09-08 18:27:59)

0

3

В каком браузере?
Возможно, где-то в #container нужно настроить ширину столбцов с помощью grid-template-columns...

Отредактировано utkin (2018-09-08 20:20:31)

0

4

Лис написал(а):

У меня не видны два правых столбца, они не помещаются, не влезают.

- Исправил, теперь таблица резиновая, там нужно было указать auto-flow; без значения по ширине... (скъюз-ми)

0

5

Сандро написал(а):

- Исправил, теперь таблица резиновая

Таблица всё равно не прокручивается по горизонтали.
Это означает, что ей нельзя будет пользоваться, когда внутрь станет набит текст (она же будет резиновая и растянется).

http://s3.uploads.ru/t/HRZ2x.gif

На данном изображении не влезло слово "рекоменду".

Хорошо, когда у Вас ширина поверхности 5760 пикселов (три монитора по 1920). А остальным что делать?

Отредактировано Лис (2018-09-08 22:56:50)

0

6

Лис написал(а):

А остальным что делать?

А остальным - ctrl + или ctrl - ... По-моему, сейчас любой браузер поддерживает масштабирование страниц.

[html]Оригинал таблицы лежит в <a class="menu-href" href="https://codepen.io/warsan/pen/KxyeOL">этой песочнице:</a> [/html] Там есть возможность сужать и замерять размеры.
За счёт авто-переноса слов внутри ячеек размер этой таблицы способен сжаться до ширины порядка 500 пикселей.  Во время сжатия минимальная ширина каждой ячейки зависит от длины самого длинного слова в ней и не зависит от количества слов, её наполняющих.
Согласно предоставленного рисунка - скриншот таблицы сделан на мониторе с шириной менее 300 пикселей. Это даже у́же, чем ширина обычного телефона.
Самый же маленький из настольных мониторов, кои мне когда-либо пришлось видеть и чинить - имели размер, пригодный для установки разрешения 640х480 пикселей, т. е. вдвое шире предоставленного скриншота.
Кроме того, встаёт вопрос: как же тогда влезла в экран вот эта недавняя картинка, (???) когда она будет куда ширше нашей таблицы, а тем более шире предоставленного скрина.
Песочницу, где можно не только проверить, но и изменить любое из качеств таблицы - на всякий случай прилагаю сюда же:

Песочница таблицы

[html]
<iframe height='501' scrolling='no' title='Таблица ' src='//codepen.io/warsan/embed/KxyeOL/?height=501&theme-id=0&default-tab=result&embed-version=2' frameborder='no' allowtransparency='true' allowfullscreen='true' style='width: 100%;'>See the Pen <a href='https://codepen.io/warsan/pen/KxyeOL/'>Таблица </a> by Сандро (<a href='https://codepen.io/warsan'>@warsan</a>) on <a href='https://codepen.io'>CodePen</a>.
</iframe>
[/html]

- И да, можно применить к ячейкам и "grid-template-columns:" с процентами, и ещё много чего, что и описано в вышеприведённой ссылочке Таблица на гридах:.
В стили добавлена строчка body{transform: scale(0.8);} Кому надо - делайте scale(0.4); или пропишите скрипт масштабирования...

0

7

grid-template-columns позволяет задать ширину колонок в % от размера таблицы. А если она резиновая, то станет по ширине рабочей области и колонки будут перестраиваться относительно общей ширины таблицы, не увеличивая ее. В теории  :crazyfun: ...

Отредактировано utkin (2018-09-09 07:54:08)

0

8

utkin написал(а):

grid-template-columns позволяет задать ширину колонок в % от размера таблицы.

- Да, ещё и авто-ширину включать: grid-template-columns: auto auto auto auto auto auto;, что я и сделал во втором варианте. Даже строку body{transform: scale(0.8);} добавил для "вящаго" счастья...
Пробовал уже и окно браузера уменьшать в-нет, и масштабировать сам браузер, - всё работает, как часы; горизонтальная и вертикальная прокрутки у браузера тоже появляются в нужный момент.

Ещё о гридах

[html]<iframe width="100%" height="800" src="https://codepen.io/warsan/pen/XPEYox" allowfullscreen="allowfullscreen" allowpaymentrequest frameborder="0"></iframe>[/html]

С каждым шагом таблица претерпевает изменения...

0

9

Ну, ждем от  Лиса название браузера.

0

10

utkin написал(а):

Ну, ждем от  Лиса название браузера.

Если немного подумать, никаких вариантов быть не может:
[html]<img src="" />[/html]

0

11

http://sd.uploads.ru/qK2X6.jpg
Усё показывает норм. Наверно старенький у Вас стоит. И вообще странно Мозилла (вместе с Оперой и Мелкософтом) состоят там в обществе любителей пихать нововведения в браузеры в строгом соответствии со стандартами. У них картель с аштэмельщиками. Именно они определяют какие фишки из стандартов HTML и CSS будут работать в браузерах, а какие нет. Причем ровно так как описано в спецификациях (а не так как удобно пользователю, как это делает Хром). И если в мозилле что-то будет показывать криво, то ровно потому что в стандарте так написано.

ЗЫ. Давно не пользовался Мозилкой и после обновлений 10-ки, он перестал открываться. Пришлось переустановить.

Отредактировано utkin (2018-09-12 10:21:37)

0

12

Нормально показывается только потому, что вы в каждую клетку не попробовали написать по абзацу длинного текста.

0

13

Лис написал(а):

Нормально показывается только потому, что вы в каждую клетку не попробовали написать по абзацу длинного текста.

- Уже попробовал. (в последнем варианте, под спойлером "Ещё о гридах")))
- Ещё раз изменил. Кто желает - может посмотреть там же...

0

14

Сандро написал(а):

в последнем варианте, под спойлером "Ещё о гридах"

http://s8.uploads.ru/t/yphEW.gif

У меня это не выглядит как приличная таблица, а выглядит как два наложенных друг на друга текста.

Отредактировано Лис (2018-09-13 01:51:46)

0

15

Лис написал(а):

У меня это не выглядит как приличная таблица, а выглядит как два наложенных друг на друга текста.

- Хе, зато при наведении курсора на "туда, где читаю", - всё становится "весьма и весьма"... )))
- А что будет, ежли мы вместе подумаем, "как, чтобы",.. (?) - Вслух, а?
Например, спрячем основной текст каждой ячейки с помощью visibility: hidden; или display: none; или opacity: 0;., а при наведении мышки на "шильдик-заголовок-преамбулу" - покажем.
И это будет не таблица уже, а целая картотека ажно, ведь преамбулы будут занимать минимум места в ячейке, а значит и таблица станет гораздо у́же, а?
Можно и конкурс организовать на тему изготовления самой красивой и вместительной таблицы-картотеки. Чья таблица больше по нраву - тому кликаем плюсик в правом углу...

0


Вы здесь » Русскоязычное программирование » web-разработка » Как сделать таблицу на гридах