我正在进行CSS网格设计,并且在桌面视图上工作正常。 ¿我如何使其具有响应性?

我将用背景图片制作一个部分,稍后再添加几篇文章以在图片上显示网格。就像我说的那样,它在台式机上运行良好,但响应速度并不理想。

我想知道如何使它响应。

非常感谢

这是我的CSS代码:

body {
        margin: 0;
        padding: 0;
        font-family: 'Arvo', serif;
        text-transform: uppercase;
        color: #FFF;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    #cuadricula {
        width: 600px;
        height: 900px;
        display: grid;
            grid-template-columns: repeat(3, 1fr);
        grid-template-rows: 100px 100px 100px 100px 100px 100px 100px 100px;
        grid-gap: 1px;
        background: #c51162;
        border: 1px solid #FFF;
        overflow: hidden;
    }

    #cuadricula__img {
        width: 600px;
        height: 900px;
        object-fit: cover;
        grid-row: 1 / 8;
        grid-column: 1/3;
    }

    .item_cuadricula_1,
    .item_cuadricula_2,
    .item_cuadricula_3,
    .item_cuadricula_4,
    .item_cuadricula_5,
    .item_cuadricula_6,
    .item_cuadricula_7,
    .item_cuadricula_8,
    .item_cuadricula_9,
    .item_cuadricula_10,
    .item_cuadricula_11,
    .item_cuadricula_12,
    .item_cuadricula_13,
    .item_cuadricula_14,
    .item_cuadricula_15,
    .item_cuadricula_16,
    .item_cuadricula_17,
    .item_cuadricula_18,
    .item_cuadricula_19,
    .item_cuadricula_20,
    .item_cuadricula_21,
    .item_cuadricula_22,
    .item_cuadricula_23,
    .item_cuadricula_24,
    .item_cuadricula_25,
    .item_cuadricula_26,
    .item_cuadricula_27 {
        border: 1px solid #FFF;
        display: flex;
        justify-content: center;
        align-items: center;
        /*            background: rgba(0, 0, 0, 0.70);*/
    }

    .item_cuadricula_1 {
        grid-column: 1;
        grid-row: 1;
        background: rgba(253, 85, 143, 0.60);
    }

    .item_cuadricula_2 {
        grid-column: 2;
        grid-row: 1;
        background: rgba(0, 57, 203, 0.60);
    }

    .item_cuadricula_3 {
        grid-column: 3;
        grid-row: 1;
        background: rgba(0, 150, 36, 0.60);
    }

    .item_cuadricula_4 {
        grid-column: 1;
        grid-row: 2;
        background: rgba(199, 165, 0, 0.60);
    }

    .item_cuadricula_5 {
        grid-column: 2;
        grid-row: 2;
        background: rgba(135, 0, 0, 0.60);
    }

    .item_cuadricula_6 {
        grid-column: 3;
        grid-row: 2;
        background: rgba(103, 218, 255, 0.60);
    }

    .item_cuadricula_7 {
        grid-column: 1;
        grid-row: 3;
        background: rgba(175, 68, 72, 0.60);
    }

    .item_cuadricula_8 {
        grid-column: 2;
        grid-row: 3;
        background: rgba(240, 98, 146, 0.60);
    }

    .item_cuadricula_9 {
        grid-column: 3;
        grid-row: 3;
        background: rgba(186, 104, 200, 0.60);
    }

    .item_cuadricula_10 {
        grid-column: 1;
        grid-row: 4;
        background: rgba(255, 241, 118, 0.60);
    }

    .item_cuadricula_11 {
        grid-column: 2;
        grid-row: 4;
        background: rgba(181, 61, 0, 0.60);
    }

    .item_cuadricula_12 {
        grid-column: 3;
        grid-row: 4;
        background: rgba(62, 39, 35, 0.60);
    }

    .item_cuadricula_13 {
        grid-column: 1;
        grid-row: 5;
        background: rgba(112, 112, 112, 0.60);
    }

    .item_cuadricula_14 {
        grid-column: 2;
        grid-row: 5;
        background: rgba(0, 178, 204, 0.60);
    }

    .item_cuadricula_15 {
        grid-column: 3;
        grid-row: 5;
        background: rgba(255, 255, 114, 0.60);
    }

    .item_cuadricula_16 {
        grid-column: 1;
        grid-row: 6;
        background: rgba(255, 241, 118, 0.60);

    }

    .item_cuadricula_17 {
        grid-column: 2;
        grid-row: 6;
        background: rgba(82, 76, 0, 0.60);
    }

    .item_cuadricula_18 {
        grid-column: 3;
        grid-row: 6;
        background: rgba(157, 70, 255, 0.60);
    }

    .item_cuadricula_19 {
        grid-column: 1;
        grid-row: 7;
        background: rgba(172, 8, 0, 0.60);
    }

    .item_cuadricula_20 {
        grid-column: 2;
        grid-row: 7;
        background: rgba(0, 136, 163, 0.60);
    }

    .item_cuadricula_21 {
        grid-column: 3;
        grid-row: 7;
        background: rgba(197, 17, 98, 0.60);
    }

    .item_cuadricula_22 {
        grid-column: 1;
        grid-row: 8;
        background: rgba(186, 104, 200, 0.60);
    }

    .item_cuadricula_23 {
        grid-column: 2;
        grid-row: 8;
        background: rgba(253, 85, 143, 0.60);
    }

    .item_cuadricula_24 {
        grid-column: 3;
        grid-row: 8;
        background: rgba(0, 57, 203, 0.60);
    }

    .item_cuadricula_25 {
        grid-column: 1;
        grid-row: 9;
        background: rgba(0, 150, 36, 0.60);
    }

    .item_cuadricula_26 {
        grid-column: 2;
        grid-row: 9;
        background: rgba(0, 178, 204, 0.60);
    }

    .item_cuadricula_27 {
        grid-column: 3;
        grid-row: 9;
        background: rgba(10, 0, 182, 0.60);
    }

    @media only screen and (max-width: 360px) {
        #cuadricula {
            grid-template-columns: 1fr 1fr 1fr;
            width: 100%;
        }
        #cuadricula__img {
            width: 100%;
            height: 900px;
        }
        .item_cuadricula_1,
        .item_cuadricula_2,
        .item_cuadricula_3,
        .item_cuadricula_4,
        .item_cuadricula_5,
        .item_cuadricula_6,
        .item_cuadricula_7,
        .item_cuadricula_8,
        .item_cuadricula_9,
        .item_cuadricula_10,
        .item_cuadricula_11,
        .item_cuadricula_12,
        .item_cuadricula_13,
        .item_cuadricula_14,
        .item_cuadricula_15,
        .item_cuadricula_16,
        .item_cuadricula_17,
        .item_cuadricula_18,
        .item_cuadricula_19,
        .item_cuadricula_20,
        .item_cuadricula_21,
        .item_cuadricula_22,
        .item_cuadricula_23,
        .item_cuadricula_24,
        .item_cuadricula_25,
        .item_cuadricula_26,
        .item_cuadricula_27 {
            background: none;
        }
        body {
            font-size: 0.5em;
        }
    }

    @media only screen and (min-width:1920px) {}


这是我的HTML

 <section id="cuadricula">
    <img src="Wonder-Woman-2017-Poster-dceu-dc-extended-universe-41499151-1382-2048.jpg" alt="Cachorro" id="cuadricula__img">


    <article class="item_cuadricula_1">fila 1 columna 1</article>
    <article class="item_cuadricula_2">fila 1 columna 2</article>
    <article class="item_cuadricula_3">fila 1 columna 3</article>

    <article class="item_cuadricula_4">fila 2 columna 1</article>
    <article class="item_cuadricula_5">fila 2 columna 2</article>
    <article class="item_cuadricula_6">fila 2 columna 3</article>

    <article class="item_cuadricula_7">fila 3 columna 1</article>
    <article class="item_cuadricula_8">fila 3 columna 2</article>
    <article class="item_cuadricula_9">fila 3 columna 3</article>

    <article class="item_cuadricula_10">fila 4 columna 1</article>
    <article class="item_cuadricula_11">fila 4 columna 2</article>
    <article class="item_cuadricula_12">fila 4 columna 3</article>

    <article class="item_cuadricula_13">fila 5 columna 1</article>
    <article class="item_cuadricula_14">fila 5 columna 2</article>
    <article class="item_cuadricula_15">fila 5 columna 3</article>

    <article class="item_cuadricula_16">fila 6 columna 1</article>
    <article class="item_cuadricula_17">fila 6 columna 2</article>
    <article class="item_cuadricula_18">fila 6 columna 3</article>

    <article class="item_cuadricula_19">fila 7 columna 1</article>
    <article class="item_cuadricula_20">fila 7 columna 2</article>
    <article class="item_cuadricula_21">fila 7 columna 3</article>

    <article class="item_cuadricula_22">fila 8 columna 1</article>
    <article class="item_cuadricula_23">fila 8 columna 2</article>
    <article class="item_cuadricula_24">fila 8 columna 3</article>

    <article class="item_cuadricula_25">fila 9 columna 1</article>
    <article class="item_cuadricula_26">fila 9 columna 2</article>
    <article class="item_cuadricula_27">fila 9 columna 3</article>


</section>

最佳答案

在这种情况下,您不应该指定grid-row和grid-column,因为它们只是一个接一个地移动。
生成grid-template-columns: 1fr 1fr 1fr时,它将所有网格元素排列在每行3列中。
而且您不必指定行模板,因为只要使用列模板有足够的元素,网格就会保留。
然后,您应该找到屏幕宽度开始崩裂的宽度,并将grid-column-template从1fr 1fr 1fr更改为1fr 1fr(或类似值)。
如果要将图像用作#cuadricula背景,则不应在HTML中添加新的<img>,而应使图像成为元素的背景图像。
因此,如果您这样编写css,则代码应具有响应能力:

#cuadricula {
        width: 600px;
        height: 900px;
        display: grid;
        grid-template-columns: auto auto auto;
        background: #c51162;
        border: 1px solid #FFF;
        overflow: hidden;
        background-image: url('http://images.fastcompany.com/upload/Simple.jpg');
        background-size: cover;
    }
    .item_cuadricula_1 {
        background: rgba(253, 85, 143, 0.60);
    }
     @media only screen and (max-width: 650px) {
        #cuadricula {
            grid-template-columns: 1fr 1fr;
            width: 100%;
        }

10-07 20:43