加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 创业 > C语言 > 正文

手机端页面自适应解决方案—rem布局

发布时间:2020-12-15 00:16:55 所属栏目:C语言 来源:网络整理
导读:table class="text" tr class="li1" td class="ln"pre class="de1"1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 =640){ docEl.style.fontSize = '100px'; }else{ docEl.style.fontSize = 100 * (cl
<tr class="li1">
<td class="ln"><pre class="de1">1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36

=640){ docEl.style.fontSize = '100px'; }else{ docEl.style.fontSize = 100 * (clientWidth / 640) + 'px'; } }; if (!doc.addEventListener) return; win.addEventListener(resizeEvt,recalc,false); doc.addEventListener('DOMContentLoaded',false); })(document,window); 如何使用? 这是rem布局的核心代码,这段代码的大意是: 如果页面的宽度超过了640px,那么页面中html的font-size恒为100px,否则,页面中html的font-size的大小为: 100 * (当前页面宽度 / 640) 于是,问题来了,为什么要这样?别急,我先来一一回答 为什么是640px? 对于手机屏幕来说,640px的页面宽度是一个安全的最大宽度,保证了移动端页面两边不会留白。注意这里的px是css逻辑像素,与设备的物理像素是有区别的。如iPhone 5使用的是Retina视网膜屏幕,使用2px x 2px的 device pixel 代表 1px x 1px 的 css pixel,所以设备像素数为640 x 1136px,而它的CSS逻辑像素数为320 x 568px。 如果要切移动端页面,你可以先把效果图宽度等比例缩放到640px,很好用。 为什么要设置html的font-size? rem就是根元素(即:html)的字体大小。html中的所有标签样式凡是涉及到尺寸的(如: height,width,padding,margin,font-size。甚至,left,top等)你都可以放心大胆的用rem作单位。 如果你把html的font-size设为20px,前面说过,rem就是html的字体大小,那么1rem = 20px。 此时,此时宽60px,高40px的元素样式就这样设置如下 ↓ width: 3rem; height: 2rem; 那要是宽55px,高37px呢?然后经过换算,,设置如下 ↓ width: 2.75rem; height: 1.85rem; 是不是发现这换算起来有点麻烦啊,,,(当然,你要是心算帝请无视) 如果我们一开始把html的font-size设为100px呢?此时1rem = 100px,那么上面的宽,高就可以这么设置 ↓ width: 0.55rem; height: 0.37rem; 是不是换算起来简单多了?! (当然可能有同学问,为什么不一开始把html的font-size设为1px呢,这样换算起来也简单,答:浏览器一般都有最小字体限制,比如谷歌浏览器,最小中文字体就是12px,所以实际上没有办法让1rem=1px。) 根据上面的js代码,如果页面宽度低于640px,那么页面中html的font-size也会按照(当前页面宽度/640)的比例变化。这样,页面中凡是应用了rem的作尺寸单位的元素都会随着页面变化而等比例缩放了! 都哪些情况可以用rem布局? 大部分情况下都可以用rem布局这个方法,当然具体还要看情况而定。拿我们公司项目举例,只有底部的导航不用rem,而是用的flex布局。因为导航点击最多,所以给它一个固定的大小(其实就是高度固定,宽度自适应的方案)。大家可以看看淘宝的这个手机页面 淘宝手机站,基本就是这种感觉,底部导航和顶部搜索框用的高固定,宽自适应的方案,其余的部分基本都是随着浏览器宽度变化在等比例缩放。 个人心得 在rem布局中,有一些自己积累的小技巧给大家分享下。 页面中模块间距离一般为0.2rem。字体的大小一般分为四个档次 0.2rem 0.24rem 0.28rem 0.32rem。 拿我们项目举例,我们移动端页面效果图的宽度都定在了640px。于是我在项目中,最外层的div样式就设置成了 position: relative; width: 100%; max-width: 640px; min-width: 320px; margin: 0 auto; 所有的元素都可以写在这个div中了,于是就可以开始写样式了 rem布局中,如果有个元素需要水平居中固定到页面底部,你会怎么设置它的样式呢。 我是这样做的,前提是这个元素还是在前面说的最外层水平居中的大div中,样式如下 position: fixed; bottom: 0; z-index: 100; width: 100%; max-width: 640px; min-width: 320px;(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

<table class="text">

    推荐文章
      热点阅读