• 经典CSS布局


    一、超级居中 place-items: center

    HTML

    <div class="parent blue" >
    <div class="box coral" contenteditable>
    :)
    </div>

    CSS

    .parent { display: grid; place-items: center; }

    二、解构煎饼式布局:flex:1 1 300px;flex-grow[定义项目的放大比例,默认为0] flex-shrink[定义了项目的缩小比例,默认为1] flex-basis[定义了在分配多余空间之前,项目占据的主轴空间(main size)]

    实际可应用于自适应样式,大屏可舒展和小屏可堆叠

    HTML

       <div class="parent2">
            <div class="child2">1:)</div>
            <div class="child2">2:)</div>
            <div class="child2">3:)</div>
        </div>
     

    CSS

        .parent2 {
            display: flex;
            flex-wrap: wrap;
        }
        .child2 {
            /* //  flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]
         //  If we don't want the items to stretch: */
            flex: 0 1 400px;
            /* //  If we do want the items to stretch:
           flex: 1 1 300px; */
            /* //   etc. */
            border: 1px solid red;
            background: lightpink;
            font-size: 2rem;
            text-align: center;
        }

    三、侧边栏布局:grid-template-columns: minmax(min, max) 1fr

    对网格布局利用了 minmax 函数。我们在这里做的是将最小侧边栏大小设置为 150px ,但在更大的屏幕上,让它伸展出 25% 。侧边栏将始终占据其父级水平空间的 25%,直到 25% 变得小于 150px 。

    HTML

     <div class="wrapper3">
            <div class="sidebar3" contenteditable>
                Min: 150px
                <br /> Max: 25%
            </div>
            <p class="content3" contenteditable>
                Lorem ipsum dolor sit amet consectetur adipisicing elit. Omnis nulla architecto maxime modi nisi. Quas saepe dolorum, architecto quia fugit nulla! Natus, iure eveniet ex iusto tempora animi quibusdam porro?</p>
        </div>

    CSS

     .wrapper3 {
            100%;
            height: 100%;
            display: grid;
            grid-template-columns: minmax(150px, 25%) 1fr;
            padding: 0;
            margin: 0;
        }
       
        .sidebar3 {
            height: 100vh;
            /*  
      //   etc. */
            background: lightpink;
            font-size: 2rem;
            text-align: center;
        }
       
        .content3 {
            padding: 2rem;
        }
     

    四、煎饼堆栈布局:grid-template-rows: auto 1fr auto

    HTML

        <div class="wrapper4">
            <header>
                <h1>Header.com</h1>
            </header>
            <main></main>
            <footer>Footer Content — Header.com 2020</footer>
        </div>

    CSS

        .wrapper4 {
            display: grid;
            
            grid-template-rows: auto 1fr auto;
        }
        /* // etc */
       
        header {
            background: lightpink;
            padding: 2rem;
        }
       
        main {
            background: coral;
        }
       
        footer {
            background: wheat;
            padding: 2rem;
            text-align: center;
        }

    五、经典圣杯布局:grid-template: auto 1fr auto / auto 1fr auto

    对于经典的圣杯布局,有页眉、页脚、左侧边栏、右侧边栏和主要内容。类似于以前的布局,但现在有侧边栏!

    HTML

        <div class="wrapper5">
           

    <header><h1 contenteditable>Header.com</h1></header>
    <div class="left-sidebar" contenteditable>Left Sidebar</div>
    <main contenteditable></main>
    <div class="right-sidebar" contenteditable>Right Sidebar</div>
    <footer contenteditable>Footer Content — Header.com 2020</footer>

        </div>

    CSS

    .wrapper5 {
    display: grid;
    height: 100vh;
    grid-template: auto 1fr auto / auto 1fr auto
    }

    // etc

    header {
    background: lightpink;
    padding: 2rem;
    grid-column: 1 / 4;
    }

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

    main {
    background: coral;
    grid-column: 2 / 3;
    }

    .right-sidebar {
    background: yellow;
    grid-column: 3 / 4;
    }

    footer {
    background: wheat;
    padding: 2rem;
    text-align: center;
    grid-column: 1 / 4;
    }

    body {
    font-family: system-ui, sans-serif;
    }

    .left-sidebar,
    .right-sidebar {
    padding: 1rem;
    }

    六、12 跨网格:grid-template-columns: repeat(12, 1fr)

    可以使用 repeat() 函数在 CSS 中快速编写网格。对网格模板列使用 repeat(12, 1fr); 将为每个 1fr 提供 12 列。

    HTML

        <div class="wrapper6">

    <div class="span-12">Span 12</div>
    <div class="span-6">Span 6</div>
    <div class="span-4">Span 4</div>
    <div class="span-2">Span 2</div>

     
        </div>

    CSS

    .wrapper6 {
    display: grid;
    height: 100vh;
    grid-template-columns: repeat(12, 1fr);
    }

    // etc

    div {
    display: grid;
    place-items: center;
    }

    .span-12 {
    background: lightpink;
    grid-column: 1 / 13;
    }

    .span-6 {
    background: lightblue;
    grid-column: 1 / 7;
    }

    .span-4 {
    background: coral;
    grid-column: 4 / 9;
    }

    .span-2 {
    background: yellow;
    grid-column: 3 / 5;
    }

    body {
    font-family: system-ui, sans-serif;
    }

    七、RAM (Repeat, Auto, MinMax): grid-template-columns(auto-fit, minmax(<base>, 1fr)) repeat(auto-fit, minmax(200px, 1fr));

    HTML

        <div class="wrapper7">

    <div>1</div>
    <div>2</div>
    <div>3</div>
    <div>4</div>

     
        </div>

    CSS

    .wrapper7 {

    display: grid;
    height: 100vh;
    grid-gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));


    }

    // etc

    div {
    display: grid;
    place-items: center;
    background: lightpink;
    }

    body {
    font-family: system-ui, sans-serif;
    }

    八、 排列布局:justify-content: space-between

    HTML

        <div class="wrapper8">

    <div class="card">
    <h1>Title - Card 1</h1>
    <p>Medium length description. Let's add a few more words here.</p>
    <div class="visual"></div>
    </div>
    <div class="card">
    <h1>Title - Card 2</h1>
    <p>Long Description. Lorem ipsum dolor sit, amet consectetur adipisicing elit. Sed est error repellat veritatis.</p>
    <div class="visual"></div>
    </div>
    <div class="card">
    <h1>Title - Card 3</h1>
    <p>Short Description.</p>
    <div class="visual"></div>
    </div>

        </div>

    CSS

    .wrapper8 {

    display: grid;
    grid-gap: 1rem;
    grid-template-columns: repeat(3, 1fr);

    }

    // etc

    .visual {
    height: 100px;
    100%;
    background: wheat;
    margin: 0.5rem 0;
    }

    .card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    background: lightpink;
    padding: 1rem;
    }

    body {
    font-family: system-ui, sans-serif;
    }

    h1 {
    font-size: 1.5rem;
    }

    九、 保持我的风格:clamp(<min><actual><max>)

    设置绝对最小和最大尺寸以及实际尺寸。有了值,应该这样:

    HTML

        <div class="wrapper9">

    <div class="card">
    <h1>Title Here</h1>
    <div class="visual"></div>
    <p>Descriptive Text. Lorem ipsum dolor sit, amet consectetur adipisicing elit. Sed est error repellat veritatis.</p>
    <br/>
    <p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Rerum eveniet beatae veritatis saepe corporis voluptates illo placeat maxime sapiente. Sit facere cumque quidem ad quo, dolores pariatur repudiandae ullam animi?</p>
    </div>

        </div>

    CSS

    .wrapper9 {

    display: grid;
    place-items: center;
    height: 100vh;

    }

    .visual {
    height: 100px;
    100%;
    background: wheat;
    margin: 0.5rem 0;
    }

    .card {
    clamp(45ch, 50%, 75ch);
    display: flex;
    flex-direction: column;
    background: lightpink;
    padding: 1rem;
    }

    body {
    font-family: system-ui, sans-serif;
    }

    h1 {
    font-size: 1.5rem;
    }

    十、  保持宽高比:aspect-ratio: <width> / <height>

    使用 aspect-ratio 属性,当调整卡片大小时,绿色视觉块保持 16 x 9 的宽高比。我们通过 aspect-ratio: 16 / 9 保持此宽高比。

    HTML

        <div class="wrapper9">

    <div class="card">
    <h1>Title Here</h1>
    <div class="visual"></div>
    <p>Descriptive Text. Lorem ipsum dolor sit, amet consectetur adipisicing elit. Sed est error repellat veritatis.</p>
    </div>

        </div>

    CSS

    .wrapper10 {

    display: grid;
    place-items: center;
    height: 100vh;

    }

    .visual {
    aspect-ratio: 16/9;
    background: wheat;
    margin: 0.5rem 0;
    }

    .card {
    80%;
    display: flex;
    flex-direction: column;
    background: lightpink;
    padding: 1rem;
    }

    body {
    font-family: system-ui, sans-serif;
    }

    h1 {
    font-size: 1.5rem;
    }

  • 相关阅读:
    线程queue
    定时器
    event模拟数据库链接
    最速下降法(梯度下降法)
    神经网络中的反向传播算法
    批量学习和在线学习的区别
    LMS算法
    粒子群算法
    遗传算法
    logistic回归
  • 原文地址:https://www.cnblogs.com/minihong/p/16394079.html
Copyright © 2020-2023  润新知