rem(js驱动和媒体查询驱动)、网格布局

网络布局的媒体查询

@media

JS驱动rem(实时变化)

主要代码

 // 实现一个事儿:让html标签的字号,是屏幕此时宽度的1/10。
        // 想清楚:屏幕的总宽度是10rem。除几,屏幕总宽度就是几rem。
        // 当屏幕尺寸改变的时候
        window.onresize = function() {
            document.documentElement.style.fontSize = document.documentElement.clientWidth / 10 + 'px';
        };

        // 页面打开那一瞬间,也设一下
        document.documentElement.style.fontSize = document.documentElement.clientWidth / 10 + 'px';
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        .box1 {
            width: 2.5rem;  
            height: 1rem;
            background-color: orange;
            float: left;
        }
        .box2 {
            width: 2.5rem;   
            height: 1rem;
            background-color: rgb(190, 10, 160);
            float: left;
        }
        .box3 {
            width: 2.5rem;   
            height: 1rem;
            background-color: rgb(35, 150, 7);
            float: left;
        }
        .box4 {
            width: 2.5rem;   
            height: 1rem;
            background-color: rgb(233, 77, 5);
            float: left;
        }
    </style>
</head>
<body>
    <div class="box1"></div>
    <div class="box2"></div>
    <div class="box3"></div>
    <div class="box4"></div>

    <script>
        // 实现一个事儿:让html标签的字号,是屏幕此时宽度的1/10。
        // 想清楚:屏幕的总宽度是10rem。除几,屏幕总宽度就是几rem。
        // 当屏幕尺寸改变的时候
        window.onresize = function() {
            document.documentElement.style.fontSize = document.documentElement.clientWidth / 10 + 'px';
        };

        // 页面打开那一瞬间,也设一下
        document.documentElement.style.fontSize = document.documentElement.clientWidth / 10 + 'px';
    </script>
</body>
</html>

媒体查询驱动rem(边界会有咯噔感)

<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        @media screen and (min-width:320px) {
            html {
                font-size: 21.33px
            }
        }

        @media screen and (min-width:360px) {
            html {
                font-size: 24px
            }
        }

        @media screen and (min-width:375px) {
            html {
                font-size: 25px
            }
        }

        @media screen and (min-width:384px) {
            html {
                font-size: 25.6px
            }
        }

        @media screen and (min-width:400px) {
            html {
                font-size: 26.67px
            }
        }

        @media screen and (min-width:414px) {
            html {
                font-size: 27.6px
            }
        }

        @media screen and (min-width:424px) {
            html {
                font-size: 28.27px
            }
        }

        @media screen and (min-width:480px) {
            html {
                font-size: 32px
            }
        }

        @media screen and (min-width:540px) {
            html {
                font-size: 36px
            }
        }

        @media screen and (min-width:720px) {
            html {
                font-size: 48px
            }
        }

        @media screen and (min-width:750px) {
            html {
                font-size: 50px
            }
        }

        * {
            margin: 0;
            padding: 0;
        }

        .c1 {
            float: left;
            width: 3rem;
            height: 3rem;
            background-color: orange;
        }

        .c2 {
            float: left;
            width: 3rem;
            height: 3rem;
            background-color: red;
        }

        .c3 {
            float: left;
            width: 3rem;
            height: 3rem;
            background-color: blue;
        }

        .c4 {
            float: left;
            width: 3rem;
            height: 3rem;
            background-color: green;
        }

        .c5 {
            float: left;
            width: 3rem;
            height: 3rem;
            background-color: skyblue;
        }
    </style>
</head>

<body>
    <div class="c1"></div>
    <div class="c2"></div>
    <div class="c3"></div>
    <div class="c4"></div>
    <div class="c5"></div>
</body>

</html>

网格布局

  • display:grid    网格容器
  • grid-template-columns   列宽
  • grid-template-rows   行高
  • grid-gap   间距

跨行 跨列

  • grid-column-start:1 列从哪个开始
  • grid-column-end:3  列到那个结束(不包含)
  • grid-column:1 / span 从第一根线开始,合并3个单元格
  • grid-row-start:1 行从哪个开始
  • grid-row-end:3 行到哪个结束(不包含)
  • grid-row:1/span 3 同上

minmax函数

minmax(300px,600px)

自定义网络模板

grid-template-area:模板样式

grid-area: 选择模板

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值