Как я могу перемещать элементы в сетке css?

#html #css

#HTML #css

Вопрос:

Я пытаюсь выяснить, как позиционировать элементы с помощью css grid. Я использую firefox и вижу, что мои области определены правильно, но когда я пытаюсь переместить некоторые образцы, они не перемещаются.

Я прочитал и попробовал кучу разных вещей, но, думаю, я неправильно применяю решения?

Я пытаюсь располагать материалы бок о бок. Например, содержимое в section1 переходит в sect1, а содержимое в sect2 переходит в section2 соответственно на странице.

Это html, который я хочу переместить с помощью css-сеток:

     <div class="wrapper">

    <header class="header">
        <!--<img class="logo" src="imgs/logo.png" alt="logo"> -->
        <h1>LOGO</h1>
        <nav>
            <ul class="nav_links">
                <li><a href="#">Home</a></li>
                <li><a href="#">Tutorials</a></li>
                <li><a href="#">About Us</a></li>
                <li><a href="#"><button class="nav_buttons">Login</button></a></li>
            </ul>
        </nav>
    </header>

    <main>
        <h2>TEXT HERE</h2>
        <div id="sect1">
            <P>MOVE ME/KEEP ME ON THE LEFT SIDE OF SCREEN</P>
        </div>
        <div id="sect2">
            <p>MOVE ME/KEEP ME ON THE RIGHT SIDE OF SCREEN</p>
        </div>
    </main>

    <footer class="foot">
    </footer>

</div>
  

Это мой файл css:

 body {
font-family: 'Roboto', sans-serif;
box-sizing: border-box;
background-color: #ededed;
margin: 0;
padding: 0;
}

.wrapper {
    display: grid;
    height: 100vh;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 80px 5fr 1fr;
    grid-template-areas: 
        "header header"
        "sect1 sect2"
        "foot foot";
}

.wrapper .header {
    grid-area: header;
}

.wrapper main {
    grid-column: 1 / 3;
}

.wrapper main #sect1 {
    grid-area: sect1;
    background-color: lightcyan;
}

.wrapper main #sect2 {
    grid-area: sect2;
    background-color: lightpink;
}

.foot {
    grid-area: foot;
    background-color: rgb(255, 0, 0);
}
  

Просмотр сетки Firefox

Ответ №1:

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

 body {
  font-family: 'Roboto', sans-serif;
  box-sizing: border-box;
  background-color: #ededed;
  margin: 0;
  padding: 0;
}

.wrapper {
  display: grid;
  height: 100vh;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 80px 5fr 1fr;
  grid-template-areas:
    "header header"
    "sect sect"
    "foot foot";
}

.wrapper .header {
  grid-area: header;
}

.wrapper main {
  grid-area: sect;
  display: grid;
  grid-template-columns: subgrid;
  grid-template-rows: auto 1fr;
}

.wrapper main h2 {
  grid-column: 1/-1;
}

.wrapper main #sect1 {
  background-color: lightcyan;
}

.wrapper main #sect2 {
  background-color: lightpink;
}

.foot {
  grid-area: foot;
  background-color: rgb(255, 0, 0);
}  
 <div class="wrapper">

  <header class="header">
    <!--<img class="logo" src="imgs/logo.png" alt="logo"> -->
    <h1>LOGO</h1>
    <nav>
      <ul class="nav_links">
        <li><a href="#">Home</a></li>
        <li><a href="#">Tutorials</a></li>
        <li><a href="#">About Us</a></li>
        <li><a href="#"><button class="nav_buttons">Login</button></a></li>
      </ul>
    </nav>
  </header>

  <main>
    <h2>TEXT HERE</h2>
    <div id="sect1">
      <P>Section 1</P>
    </div>
    <div id="sect2">
      <p>Section 2</p>
    </div>
  </main>

  <footer class="foot">
  </footer>

</div>  

Комментарии:

1. Ах! Спасибо! Я не знал, что есть такая вещь, как подсетка.

Ответ №2:

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

 body {
  font-family: 'Roboto', sans-serif;
  box-sizing: border-box;
  background-color: #ededed;
  margin: 0;
  padding: 0;
}

.wrapper {
    display: grid;
    height: 100vh;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 80px 5fr 1fr;
    grid-template-areas:
        "header header"
        "main main"
        "foot foot";
}

.wrapper .header {
    grid-area: header;
}

.wrapper main {
  grid-area: main;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 150px 1fr;
  grid-template-areas:
    "text text"
    "sect1 sect2"
}

.wrapper #sect1 {
    grid-area: sect1;
    background-color: lightcyan;
}

.wrapper #sect2 {
    grid-area: sect2;
    background-color: lightpink;
}

.foot {
    grid-area: foot;
    background-color: rgb(255, 0, 0);
}  
 <!DOCTYPE html>
<html lang="en" dir="ltr">

<head>
  <meta charset="utf-8">
  <title>Test</title>
  <link rel="stylesheet" href="main.css">
</head>

<body>
  <div class="wrapper">

    <header class="header">
      <!--<img class="logo" src="imgs/logo.png" alt="logo"> -->
      <h1>LOGO</h1>
      <nav>
        <ul class="nav_links">
          <li><a href="#">Home</a></li>
          <li><a href="#">Tutorials</a></li>
          <li><a href="#">About Us</a></li>
          <li><a href="#"><button class="nav_buttons">Login</button></a></li>
        </ul>
      </nav>
    </header>

    <main>
      <h2>TEXT HERE</h2>
      <div id="sect1">
        <p>Section 1</p>
      </div>
      <div id="sect2">
        <p>Section 2</p>
      </div>
    </main>

    <footer class="foot">
    </footer>

  </div>
</body>

</html>  

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