Заполните вертикально, но сохраняйте ширину в соответствии с содержанием - PullRequest
3 голосов
/ 05 июля 2019

В следующем примере:

html {
  height: 100%;
}

body {
  height: 100%;
  margin: 0;
}

#main {
  height: 100%;
  margin: 0;
  display: flex;
  flex-direction: row;
}

#whiteboard {
  flex: 1 1 auto;
  background-color: LightGreen;
  display: inline-flex;
  flex-direction: column;
}

#whiteboardPanel {
  display: inline-flex;
  overflow: auto;
}

#whiteboardContent {
  height: 1000px;
  width: 100px;
  background-color: White;
}
<div id="main">
  <div id="whiteboard">
    <div id="whiteboardPanel">
      <div id="whiteboardContent">Blah, blah, ...</div>
    </div>

    <div>Some buttons here</div>
  </div>
</div>

Полоса прокрутки появляется в правой части окна.Мне нравится, когда он касается белой части, то есть содержимого div "whiteboardPanel".

Кажется, проблема в том, что whiteboardPanel увеличивается до использования всей ширины окна.Мне нужно сохранить ширину этого div в соответствии с его содержимым (div "whiteboardContent" в примере), без увеличения.

Примечания:

  • html, определения body и mainиспользуется в некоторых других элементах страницы, лучше оставить их как есть.
  • , если возможно, "#whiteboard" должен охватывать все окна .В реальном случае на этом уровне появятся некоторые другие div, братья этого div, в строках и размещенные слева от этого div.«whiteboard» - это та, которая должна расти, чтобы заполнить все доступное пространство.
  • Это плюс, если «whiteboardPanel» и кнопки могут отображаться по центру по горизонтали, не касаясь левой стороны окна.
  • Решения в простом html, css и javascript предпочтительнее, чем другие, основанные на внешних библиотеках, как jQuery.
  • Я знаю, что есть несколько похожих вопросов, но еще не найдено ни одного с применимым решением.

Ответы [ 2 ]

2 голосов
/ 05 июля 2019

Исходя из того, что я понимаю о ваших требованиях, я думаю, что лучшее решение заключается во вложении контента в дополнительную оболочку.Это дополнительно изолирует содержимое от остальной части контейнера, позволяя использовать целевую полосу прокрутки.

#main {
  height: 100vh;
  display: flex;
}

#whiteboard {
  flex: 1;
  display: flex;
  flex-direction: column;
  background-color: LightGreen;
}

#whiteboardPanel {
  min-height: 0;  /* https://stackoverflow.com/q/36247140/3597276 */
  display: flex;
}

#whiteboardContent {
  overflow: auto;
  width: 100px;
  background-color: White;
  display: flex;
}

#whiteboardContent>span {
  height: 1000px;
}

body {
  margin: 0;
}
<div id="main">
  <div id="whiteboard">
    <div id="whiteboardPanel">
      <div id="whiteboardContent">
        <span>Blah, blah, ...</span>
      </div>
    </div>
    <div>Some buttons here</div>
  </div>
</div>

jsFiddle demo

2 голосов
/ 05 июля 2019

Ваше правило #whiteboard устанавливает гибкость на 1 1 авто. Это означает, что ваша гибкая основа занимает 100% пространства. Измените это, и размер будет ограничен содержанием.

html {
  height: 100%;
}

body {
  height: 100%;
  margin: 0;
}

#main {
  height: 100%;
  margin: 0;
  display: flex;
  flex-direction: row;
}

#whiteboard {
  background-color: LightGreen;
  display: inline-flex;
  flex-direction: column;
}

#whiteboardPanel {
  display: inline-flex;
  overflow: auto;
  position: relative;
  /* any non static, to allow child position absolute */
}

#whiteboardContent {
  height: 1000px;
  width: 100px;
  background-color: White;
}
<div id="main">
  <div id="whiteboard">
    <div id="whiteboardPanel">
      <div id="whiteboardContent">Blah, blah, ...</div>
    </div>

    <div>Some buttons here</div>
  </div>
</div>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...