响应式布局

vw、vh

1 vw = 1% 视口宽度

如果要在 750 px 设计稿中使用 vw 做响应式

1 vw = 7.5 px , 1px = 1 / 7.5 vw

  • test.html
<!doctype html>  
<html lang="en">  
<head>  
  <meta charset="UTF-8">  
  <meta name="viewport"  
        content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">  
  <meta http-equiv="X-UA-Compatible" content="ie=edge">  
  <title>Document</title>  
  <link href="./test.css" rel="stylesheet">  
</head>  
<body>  
<div class="box">  
  hello word  
</div>  
</body>  
</html>
  • test.scss
    • 如果要在 750 设计稿中,宽度为 100px,那么就写成 100vw/$vw width: 100vw/$vw;
body {  
  margin: 0;  
}  
  
$vw: 7.5;  
  
.box {  
  // 如果要在 750 设计稿中,宽度为 100px,那么就写成 100vw/$vw  width: 100vw/$vw;  
  height: 100vw/$vw;  
  background: #000;  
}
  • test.css
body {  
  margin: 0;  
}  
  
.box {  
  width: 13.3333333333vw;  
  height: 13.3333333333vw;  
  background: #000;  
}

rem

1 rem = 1 html根字号

  • test.html
<!doctype html>  
<html lang="en">  
<head>  
  <meta charset="UTF-8">  
  <meta name="viewport"  
        content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">  
  <meta http-equiv="X-UA-Compatible" content="ie=edge">  
  <title>test</title>  
  <script>  
   const rootEl = document.documentElement;  
   const viewportWidth = window.innerWidth;  
  
   rootEl.style.fontSize = viewportWidth / 25 + 'px';  
  </script>  
  <link href="./test.css" rel="stylesheet">  
</head>  
<body>  
<div class="box">  
  hello word  
</div>  
</body>  
</html>  
  • 以 25份为基准

    • 屏幕分成 25 份, html 的 font-size: viewportWidth / 25 + ‘px’; 也就是 4vw
  • 设计稿也要分成 25 份

    • 750px 设计稿分成 25 份
    • 750 px / 25 = 30 px, 1 份 = 30 px 1 rem = 30 px
  • test.scss

body {  
  margin: 0;  
}  
  
$rem: 30;  
  
.box {  
  width: 375rem/$rem;  
  height: 100px;  
  background: palegoldenrod;  
}
  • 转换成 css test.css
body {  
  margin: 0;  
}  
  
.box {  
  width: 12.5rem;  
  height: 100px;  
  background: palegoldenrod;  
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值