rem布局样例
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no" > <title>rem布局样例</title> <style> *{ margin: 0; padding: 0; box-sizing: border-box; } body{ background: #eef3f6; } .btndelete{ border: 0.01rem solid #fc5630; width: 1.1rem; height: 0.5rem; line-height: 0.5rem; background: none; color: #fc5630; border-radius: 0.25rem; outline: none; font-size: 0.28rem; } .wrap{ position: relative; padding-top: 1.2rem; } .wrap .bg{ position: absolute; top: 0; width: 100%; height: 3.5rem; background: url(); background-repeat: no-repeat; background-size: 100% 100%; } .wrap .studetail{ height: 3.6rem; background: #fff; border-radius: 0.08rem; margin: 0 .2rem; position: relative; z-index: 1; box-shadow: 0px 0.03rem 0.1rem #ddd; overflow: hidden; } .wrap .studetail .btndelete{ position: absolute; top: 0.3rem; right: 0.3rem; } .wrap .studetail .studetail_top,.wrap .studetail .studetail_bottom{ display: flex; align-items: center; text-align: center; justify-content: center; } .wrap .studetail .studetail_top{ height: 2.6rem; font-size: 0.3rem; color: #333; } .wrap .studetail .studetail_top .stu_info{ height: 1.9rem; display: flex; flex-direction: column; justify-content: space-between; } .wrap .studetail .studetail_top .stu_info .img{ height: 1.4rem; width: 1.4rem; border: 0.06rem solid #c5e9fa; border-radius: 50%;; } .wrap .studetail .studetail_bottom{ height: 1rem; border-top: 0.01rem dashed #ddd; font-size: 0.26rem; color: #666; } .wrap .parent_box{ padding: 0 .2rem; } .wrap .parent_box .parent_title{ padding: 0.36rem 0 0.16rem; font-weight: bold; font-size: 0.28rem; color: #333; } .wrap .parent_box .parent_list .item:first-child{ border-top: 0.01rem solid #e1e7ec; } .wrap .parent_box .parent_list .item{ padding: 0 .24rem; height: 1rem; border-bottom: 0.01rem solid #e1e7ec; background: #fff; font-size: 0.28rem; color: #333; display: flex; align-items: center; justify-content: space-between; } .wrap .determine{ width: 3.4rem; line-height: 1rem; margin:0.6rem auto; color: #fff; border-radius: 0.5rem; font-size: 0.36rem; text-align: center; background: linear-gradient(to right, #fc8b05 , #fc7305); } </style> </head> <body> <div class="wrap"> <div class="bg"></div> <div class="studetail"> <button class="btndelete" type="button" name="button">移除</button> <div class="studetail_top"> <div class="stu_info"> <div class="img"></div> <div class="name">詹姆斯</div> </div> </div> <div class="studetail_bottom"> <div>三年二班的刘小,刘迪家长的孩子</div> </div> </div> <div class="parent_box"> <div class="parent_title">关联家长</div> <div class="parent_list"> <div class="item"> <div>刘吴迪(爸爸)</div> <div>13659646789</div> <button class="btndelete" type="button" name="button">移除</button> </div> <div class="item"> <div>刘吴迪(爸爸)</div> <div>13659646789</div> <button class="btndelete" type="button" name="button">移除</button> </div> <div class="item"> <div>刘吴迪(爸爸)</div> <div>13659646789</div> <button class="btndelete" type="button" name="button">移除</button> </div> </div> </div> <div class="determine"> 确 定 </div> </div> <script> // https://blog.csdn.net/TCF_JingFeng/article/details/80814015 /* 设计稿的宽度:designWidth 允许自适应的最大宽度(超过这个值屏幕元素不在自适应增大):maxWidth 页面顶部加上:<meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no" > 这段js的传入两个参数:一个为设计稿实际宽度,一个为显示的最大宽度(允许的屏幕最大宽度,用来限制屏幕过大之后元素还会自适应增大的) 例如设计稿为750,最大宽度为600,则为(750,600),屏幕大于600之后就不会自适应变大了,也相当于在用@media属性时min-width只设置到了600,没有后面的屏幕尺寸,就不会再变化了 公式:1rem = 浏览器屏幕宽(width) * 100 / 设计稿宽(designWidth) (750,750)含义1rem = clientWidth * 100 / 750 (750,2160)含义1rem = clientWidth * 100 / 750 clientWidth是动态获取的 后面的750和2160表示maxWidth,如果浏览器窗口(clientWidth)大于这个数值就将clientWidth设置成这个数值(maxWidth)。而width是根据屏幕变化动态获取的 */ ;(function (designWidth, maxWidth) { var doc = document, win = window, docEl = doc.documentElement, remStyle = document.createElement("style"), tid; function refreshRem() { var clientWidth = docEl.getBoundingClientRect().width;//获取document的宽度,浏览器屏幕宽度 // alert(clientWidth) maxWidth = maxWidth || 540;//短路运算符,如果前面式子为false再执行后面,如果赋值了maxWidth那么maxWidth=maxWidth,否则没有赋值那么maxWidth为false,就会执行maxWidth=540 clientWidth > maxWidth && (clientWidth = maxWidth);//短路运算符,如果前面式子true再执行后面 var rem = clientWidth * 100 / designWidth; remStyle.innerHTML = 'html{font-size:' + rem + 'px;}'; } if (docEl.firstElementChild) { docEl.firstElementChild.appendChild(remStyle); } else { var wrap = doc.createElement("div"); wrap.appendChild(remStyle); doc.write(wrap.innerHTML); wrap = null; } refreshRem(); //要等 wiewport 设置好后才能执行 refreshRem,不然 refreshRem 会执行2次; win.addEventListener("resize", function () { clearTimeout(tid); //防止执行两次 tid = setTimeout(refreshRem, 300); }, false); /* 浏览器后退的时候重新计算,为了查看页面是直接从服务器上载入还是从缓存中读取,你可以使用 PageTransitionEvent 对象的 persisted 属性来判断。 如果页面从浏览器的缓存中读取该属性返回 ture,否则返回 false */ win.addEventListener("pageshow", function (e) { if (e.persisted) { clearTimeout(tid); tid = setTimeout(refreshRem, 300); } }, false); /* 为什么一般多是 html{font-size:62.5%;} 而不是 html{font-size:10px;}呢? 因为有些浏览器默认的不是16px,或者用户修改了浏览器默认的字体大小(因浏览器分辨率大小,视力,习惯等因素)。 如果我们将其设置为10px,一定会影响在这些浏览器上的效果,所以最好用绝大多数用户默认的16作为基数 * 62.5% 得到我们需要的10px。 实际项目设置成 font-size: 62.5%可能会出现问题,因为chrome不支持小于12px的字体,计算小于12px的时候,会默认取12px去计算,导致chrome的em/rem计算不准确。 针对这个现象,可以尝试设置html字体为100px,body 修正为16px,这样 0.1rem 就是 10px,而body的字体仍然是默认大小,不影响未设置大小的元素的默认字体的大小。 */ if (doc.readyState === "complete") { doc.body.style.fontSize = "16px";//页面元素默认16px,如果不设置将是自动为16px显示 } else { doc.addEventListener("DOMContentLoaded", function (e) { doc.body.style.fontSize = "16px"; }, false); } })(750, 750); </script> </body> </html>