Отзывчиво сложите три деления справа, которые не все справа для начала - PullRequest
0 голосов
/ 31 августа 2018

Я использую display: grid вместе с display: flex для создания макета, подобного тому, который называется 'Normal' на изображении ниже. У меня также есть некоторый JavaScript, который позволяет мне свернуть синие и голубые div. У меня очень трудное время при создании медиа-запроса, который позволит мне расположить все элементы div справа, как на картинке. Красный div расширяется до размера его содержимого, в то время как синий div получает переполнение: прокрутка. Two-column to one-column responsive layout Это изображение немного упрощает реальную ситуацию; У меня на самом деле тоже есть что-то посередине страницы. Вот урезанная версия моего html (я знаю, что сетка немного отличается от той, что на картинке выше):

<html>
<head>
  <title>Width Test</title>
  <link rel="stylesheet" href="ResponsiveWidth.css">
</head>
<body>
    <div class="left">
      <div class="one"><p>One</p>
        Bacon ipsum dolor amet andouille pork belly shankle bacon landjaeger, cupim flank meatball t-bone capicola leberkas. Tenderloin short loin venison ribeye drumstick, corned beef pork belly pork chop jerky kielbasa salami cupim. Drumstick ham hock filet mignon rump doner. Ham tri-tip venison hamburger rump, jowl ball tip bresaola tenderloin jerky. Chicken cow salami, chuck pancetta tail swine pork loin pork chop turkey beef ribs capicola boudin.

        Meatball flank t-bone pancetta spare ribs landjaeger boudin pork chop leberkas jerky alcatra meatloaf swine ball tip. Pork chop meatball beef ribs ribeye t-bone. Tongue pig flank shoulder alcatra doner ground round kielbasa jerky bresaola beef swine. Tenderloin swine ribeye andouille tongue drumstick fatback.

        Ball tip shankle brisket shoulder salami bresaola leberkas alcatra venison short ribs meatloaf ground round pastrami t-bone flank. Chuck bacon bresaola alcatra t-bone ribeye shank drumstick pork filet mignon ham hock burgdoggen chicken doner. Tenderloin shoulder spare ribs, burgdoggen hamburger sirloin cupim pork loin turkey short loin tail jowl ham hock. Sausage jerky alcatra, ground round cupim chicken short loin turducken bresaola porchetta beef ribs capicola pastrami meatloaf. Rump bacon doner buffalo short loin picanha drumstick cupim.
      </div>
      <div class="two"><p>Two</p>
        Bacon ipsum dolor amet andouille pork belly shankle bacon landjaeger, cupim flank meatball t-bone capicola leberkas. Tenderloin short loin venison ribeye drumstick, corned beef pork belly pork chop jerky kielbasa salami cupim. Drumstick ham hock filet mignon rump doner. Ham tri-tip venison hamburger rump, jowl ball tip bresaola tenderloin jerky. Chicken cow salami, chuck pancetta tail swine pork loin pork chop turkey beef ribs capicola boudin.

        Meatball flank t-bone pancetta spare ribs landjaeger boudin pork chop leberkas jerky alcatra meatloaf swine ball tip. Pork chop meatball beef ribs ribeye t-bone. Tongue pig flank shoulder alcatra doner ground round kielbasa jerky bresaola beef swine. Tenderloin swine ribeye andouille tongue drumstick fatback.

        Ball tip shankle brisket shoulder salami bresaola leberkas alcatra venison short ribs meatloaf ground round pastrami t-bone flank. Chuck bacon bresaola alcatra t-bone ribeye shank drumstick pork filet mignon ham hock burgdoggen chicken doner. Tenderloin shoulder spare ribs, burgdoggen hamburger sirloin cupim pork loin turkey short loin tail jowl ham hock. Sausage jerky alcatra, ground round cupim chicken short loin turducken bresaola porchetta beef ribs capicola pastrami meatloaf. Rump bacon doner buffalo short loin picanha drumstick cupim.
      </div>
    </div>
    <div class="right">
      <div class="three"><p>Three<p>
        Bacon ipsum dolor amet andouille pork belly shankle bacon landjaeger, cupim flank meatball t-bone capicola leberkas. Tenderloin short loin venison ribeye drumstick, corned beef pork belly pork chop jerky kielbasa salami cupim. Drumstick ham hock filet mignon rump doner. Ham tri-tip venison hamburger rump, jowl ball tip bresaola tenderloin jerky. Chicken cow salami, chuck pancetta tail swine pork loin pork chop turkey beef ribs capicola boudin.

        Meatball flank t-bone pancetta spare ribs landjaeger boudin pork chop leberkas jerky alcatra meatloaf swine ball tip. Pork chop meatball beef ribs ribeye t-bone. Tongue pig flank shoulder alcatra doner ground round kielbasa jerky bresaola beef swine. Tenderloin swine ribeye andouille tongue drumstick fatback.

        Ball tip shankle brisket shoulder salami bresaola leberkas alcatra venison short ribs meatloaf ground round pastrami t-bone flank. Chuck bacon bresaola alcatra t-bone ribeye shank drumstick pork filet mignon ham hock burgdoggen chicken doner. Tenderloin shoulder spare ribs, burgdoggen hamburger sirloin cupim pork loin turkey short loin tail jowl ham hock. Sausage jerky alcatra, ground round cupim chicken short loin turducken bresaola porchetta beef ribs capicola pastrami meatloaf. Rump bacon doner buffalo short loin picanha drumstick cupim.
      </div>
    </div>
</body>
</html>

И мой css:

body {
  min-height: 100%;
  display: grid;
  height: 100%;
  margin: 0;
  width: 100%;
  grid-template-columns: repeat(3, 300px);
  grid-template-rows: 600px;
  overflow: hidden;
}


.left, .right {
  grid-row-start: 1;
  display: flex;
  justify-content: space-around;
  flex-direction: column;
}

.left {
  grid-column: 1/2;
}

.right {
  grid-column: 3/4;

}

.one, .two, .three {
  padding: 20px;
  overflow: scroll;
}

.one {
  background-color: red;
}

.two {
  background-color: blue;
}

.three {
  background-color: #00ffff;
}

/* Media Queries */
@media screen and (max-width: 960px) {
  .left {
    grid-column: 3/4;
  }
}

Я пытался поместить элементы div в одно и то же место, используя grid-столбец, но они просто перекрывают друг друга, а не разделяют пространство. Как мне это сделать?

1 Ответ

0 голосов
/ 31 августа 2018

Я настоятельно рекомендую вам прочитать эту статью, чтобы дать вам прочную основу по сеткам CSS:

https://css -tricks.com / сниппеты / CSS / полн-гид-сетка /

Что касается вашего вопроса:

Прежде всего, давайте сделаем отступ в вашем коде и добавим некоторые теги

к этим плавающим блокам текста, чтобы сделать все немного более читабельным:)

Сделав это, чтобы изменить расположение ваших элементов внутри сетки, используйте

  • сетка-столбец стартером
  • сетка-колонный конец
  • Сетка-рядного начать
  • Сетка-рядный конец

В вашем коде у вас есть сетка 3х3, поэтому, если вы хотите придерживаться этого, я подготовил для вас пример кода. Если вы хотите полностью придерживаться примеров изображений, вам потребуется более детально прорисовать вашу сетку.

А пока, если вы исправите свой CSS, используя сетку 3x3, медиа-запрос должен сработать, и у вас должно получиться следующее:

enter image description here

CSS + HTML это:

body {
min-height: 100%;
display: grid;
height: 100%;
margin: 0;
width: 100%;
grid-template-columns: repeat(3, 300px);
grid-template-rows: repeat(3, 200px);
overflow: hidden;
}


.left, .right {
grid-row: 1/4;
display: flex;
justify-content: space-around;
flex-direction: column;
}

.left {
//grid-column: 1/2;
}

.right {
grid-column: 3/4;

}

.one, .two, .three {
padding: 20px;
overflow: scroll;
}

.one {
background-color: red;
}

.two {
background-color: blue;
}

.three {
background-color: #00ffff;
}

/* Media Queries */
@media screen and (max-width: 960px) {
    
    .left {
        grid-column-start: 3;
        grid-row-start: 1;
        grid-row-end: span 2;
        order: 1;
    }
    .left .one {
        grid-row-start:1;
        grid-row-end:1;
    }
    .left .two {
        grid-row-start:1;
        grid-row-end:2;
    }
    .right {
        grid-column-start:3;
        grid-row-start:3;
        grid-row-end:3;
        order:2;
    }
}
<html>
<head>
<title>Width Test</title>
<link rel="stylesheet" href="ResponsiveWidth.css">
</head>
    
<body>
    <div class="left">
        <div class="one">
            <p>One</p>
            <p>Bacon ipsum dolor amet andouille pork belly shankle bacon landjaeger, cupim flank meatball t-bone capicola leberkas. Tenderloin short loin venison ribeye drumstick, corned beef pork belly pork chop jerky kielbasa salami cupim. Drumstick ham hock filet mignon rump doner. Ham tri-tip venison hamburger rump, jowl ball tip bresaola tenderloin jerky. Chicken cow salami, chuck pancetta tail swine pork loin pork chop turkey beef ribs capicola boudin.</p>

            <p>Meatball flank t-bone pancetta spare ribs landjaeger boudin pork chop leberkas jerky alcatra meatloaf swine ball tip. Pork chop meatball beef ribs ribeye t-bone. Tongue pig flank shoulder alcatra doner ground round kielbasa jerky bresaola beef swine. Tenderloin swine ribeye andouille tongue drumstick fatback.</p>

            <p>Ball tip shankle brisket shoulder salami bresaola leberkas alcatra venison short ribs meatloaf ground round pastrami t-bone flank. Chuck bacon bresaola alcatra t-bone ribeye shank drumstick pork filet mignon ham hock burgdoggen chicken doner. Tenderloin shoulder spare ribs, burgdoggen hamburger sirloin cupim pork loin turkey short loin tail jowl ham hock. Sausage jerky alcatra, ground round cupim chicken short loin turducken bresaola porchetta beef ribs capicola pastrami meatloaf. Rump bacon doner buffalo short loin picanha drumstick cupim.</p>
</div>
        <div class="two"><p>Two</p>
            <p>Bacon ipsum dolor amet andouille pork belly shankle bacon landjaeger, cupim flank meatball t-bone capicola leberkas. Tenderloin short loin venison ribeye drumstick, corned beef pork belly pork chop jerky kielbasa salami cupim. Drumstick ham hock filet mignon rump doner. Ham tri-tip venison hamburger rump, jowl ball tip bresaola tenderloin jerky. Chicken cow salami, chuck pancetta tail swine pork loin pork chop turkey beef ribs capicola boudin.</p>

            <p>Meatball flank t-bone pancetta spare ribs landjaeger boudin pork chop leberkas jerky alcatra meatloaf swine ball tip. Pork chop meatball beef ribs ribeye t-bone. Tongue pig flank shoulder alcatra doner ground round kielbasa jerky bresaola beef swine. Tenderloin swine ribeye andouille tongue drumstick fatback.</p>

            <p>Ball tip shankle brisket shoulder salami bresaola leberkas alcatra venison short ribs meatloaf ground round pastrami t-bone flank. Chuck bacon bresaola alcatra t-bone ribeye shank drumstick pork filet mignon ham hock burgdoggen chicken doner. Tenderloin shoulder spare ribs, burgdoggen hamburger sirloin cupim pork loin turkey short loin tail jowl ham hock. Sausage jerky alcatra, ground round cupim chicken short loin turducken bresaola porchetta beef ribs capicola pastrami meatloaf. Rump bacon doner buffalo short loin picanha drumstick cupim.</p>
</div>
        </div>
    <div class="right">
        <div class="three"><p>Three<p>
            <p>Bacon ipsum dolor amet andouille pork belly shankle bacon landjaeger, cupim flank meatball t-bone capicola leberkas. Tenderloin short loin venison ribeye drumstick, corned beef pork belly pork chop jerky kielbasa salami cupim. Drumstick ham hock filet mignon rump doner. Ham tri-tip venison hamburger rump, jowl ball tip bresaola tenderloin jerky. Chicken cow salami, chuck pancetta tail swine pork loin pork chop turkey beef ribs capicola boudin.</p>

            <p>Meatball flank t-bone pancetta spare ribs landjaeger boudin pork chop leberkas jerky alcatra meatloaf swine ball tip. Pork chop meatball beef ribs ribeye t-bone. Tongue pig flank shoulder alcatra doner ground round kielbasa jerky bresaola beef swine. Tenderloin swine ribeye andouille tongue drumstick fatback.</p>

            <p>Ball tip shankle brisket shoulder salami bresaola leberkas alcatra venison short ribs meatloaf ground round pastrami t-bone flank. Chuck bacon bresaola alcatra t-bone ribeye shank drumstick pork filet mignon ham hock burgdoggen chicken doner. Tenderloin shoulder spare ribs, burgdoggen hamburger sirloin cupim pork loin turkey short loin tail jowl ham hock. Sausage jerky alcatra, ground round cupim chicken short loin turducken bresaola porchetta beef ribs capicola pastrami meatloaf. Rump bacon doner buffalo short loin picanha drumstick cupim.</p>

        </div>
    </div>
    
</body>
</html>

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

Надеюсь, это поможет G

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