接地气的来讲《rem机制》+ vw,vh单位

rem到是个什么原理?身为一个前段新手,我发现还有很多身边的朋友不能很刻骨的理解rem到底是个什么贵意思,介于我不想再每次上班的时候溜出去蹲厕所打电话给身边的朋友解释这个,我要罗列出来我的思路,接地气的思路。

学习前端开发的很多同学都接触过淘宝的flexible,很方便的适配,它是将页面分割成10等分,然后直接在页面上引用cdn就可以实现,或者将源码copy下来放在自己的项目中本地引入,我不详细的介绍源码,下面详细的介绍rem的原理,看完就自然明白flexible的原理了。

在没有rem这个单位之前,我们移动端用px或者em,em是个相对单位,是根据当前字体大小来定义的,根据W3标准,它们是相对于使用em单位的元素的字体大小。这句话怎么理解?假如一个p标签,你没有设定它的字体大小,但是因为字体大小这个属性是会继承的,它继承了父容器的字体大小,或者是父父父。。。容器的,那么你写1em就会等于这个被继承的父容器的字体大小,那也就是说,

<div class="1" style="font-size:20px">

    <div class="2" style="font-size:16px">

        <p style="font-size:1em">

            就是我了

        </p>

    </div>

</div>

此时的p标签的字体大小为16px;也就是说要这样

<div class="1" style="font-size:20px;">

    <span class="1-1" style="font-size:0.8em">后来的我</span>

    <div class="2" style="font-size:16px;">

        <p style="font-size:1em;">

            就是我了

        </p>

    </div>

</div>

这样子我的span里面的字体才能跟p里面的字体做到一样大小;看到不同了吗?

这就是em后来渐渐被取代的原因,因为它还是不够方便,有的时候我们要做的换算还是过多了,所以前辈们创造了新的单位《rem》,rem也是在px上升级的,下面我们正式介绍一下rem为什么会更方便,所以被造出来

首先,rem是根据跟字体的大小来定义的,什么叫跟字体大小,我们知道代码里面页面的根本就是html和body,rem就是被定义为相对于html,body里面的字体大小来转换的,那为什么它就方便了呢?因为跟字体的大小不会改变,你定义了是多少就是多少,没定义的话就是默认大小,不会因为你后面元素的字体大小的重新设定而改变,所以,还是上面这个例子,我类名就是用数字了,看着个别扭,(用图片吧,这上面写的有点累)


看,span里面的字体跟p里面的一样大了(真的一样大,我没有把调试一起截图下来而已,你要相信我 >_<)

区别是什么,span和p里面的字体大小已经不被其他的div的字体大小影响了,只跟随html,body的字体大小变化。

这就是rem的方便之处,减少了很多换算,将相对的对象统一成一个(——跟字体),现在知道rem是个什么东西了吧,那我们来说一下有关于不同手机屏幕大小的适配问题,以前用px,em的时候要去写@media screen { } ,(媒体查询)。要为每个容器去重新写一遍单位大小,这样是很不方便的,那rem不是不用去写@media screen { },而是要写的就少很多很多了,我只要去写跟字体大小的@media screen { }就好了,来看看效果


等比例缩小了,有木有!文字大小会随屏幕的大小的变化而变大变小,再也不用单独写span的媒体查询和p的媒体查询了,这就是rem机制的方便之处

其实说白了,就这么个意思,我们用rem单位的时候不是为了省去媒体查询不写,写还是要写的,只是再也不用写一大堆重复的代码了,只要管好你的跟字体大小就好了,不同的屏幕去写不同的跟字体的媒体查询,比如说6p,又要再大一点 的字体,也就是多谢一行代码的事了。

(好了,再有朋友问我为什么我用了rem换了不同屏幕的手机还是会炸这样的问题,我不用再溜出办公室去打电话解释了,我觉得这里我说的已经跟接地气了,不存在听不懂的吧hhhhhhh)

另: rem的原理就是这样,其实可以写的更优雅一点的就是用js来实现这个适配,相信很多人也在网上看到过这样的js,我顺带提一下,这样的js原理也就是自动去获取屏幕的宽度,然后根据不同屏幕的宽度用js去修改跟字体的大小,这样就可以连媒体查询也省略了呢,但其实也就是我们手写的媒体查询一样的原理


vw单位用的人较少,vw是我写移动端很喜欢的用的单位(vh一样),vw的原理很好理解,view width,可视区域的宽度,也就是手机的宽度(vh 就是view height,后面只说vw,vh一样理解就可以);这里vw算的是屏幕的百分比,举一个例子很直观的理解


50%跟50vw简直一摸一样嘛,是吗?在这里是一样的,还有不一样的情况,再来看这一个效果就了然了


当我把这个叫aa的div容器宽度改为100px时,50%自然就变成了50px,像上面一样


这个叫aa的div容器宽度依然还是100px,子容器bb的宽度为50vw,结果,50vw代表的是屏幕的一半,并不是100px的一半,这样看起来vw跟%的区别就好像rem跟em的区别一样,一个是相对于父容器定义大小,一个是相对于某个指定不变的参照物(rem相对于跟字体,vw相对于屏幕宽度)而且,vw不用做响应式操作,因为是相对于手机屏幕来写的宽度,所以你用iphone6看的话它就是ip6的一半宽,用iphone5看的话,它就是ip5的一半宽,简直方便的不要不要的

vh跟vw一样的原理,相对于屏幕的高度,一般移动端的开发,写死高度的地方稍微少一点,其实高度用px也可以,毕竟移动端是可以上下滚动的嘛,这里说一下,高度也可以用vw的,建议,移动端开发的时候,一半普通的小号字体的文字,直接就用px就好了,没必要这样的文字也要根据屏幕大小变化而变化(有特殊需求除外)

rem跟vw都能实现不同大小的屏幕兼容,具体用哪一个,看你的心情了emmmmmmmmmmm

<小菜鸟心得,有问题请拍砖>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,440评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,814评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,427评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,710评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,625评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,014评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,511评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,162评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,311评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,262评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,278评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,989评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,583评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,664评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,904评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,274评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,856评论 2 339

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,721评论 1 92
  • 什么是Rem rem和em很容易混淆,其实两个都是css的单位,并且也都是相对单位,现有的em,css3才引入的r...
    tobAlier阅读 27,819评论 2 38
  • 作者:HelKyle链接:http://www.w3cplus.com/css/when-to-use-em-vs...
    红叶丶秋鸣阅读 3,196评论 0 3
  • 单位,在各个领域都是很常见的。那么在前端领域用到了哪些单位呢,这篇文章让我们细细了解一下! 下面我讲列举:pt、p...
    贵在随心阅读 5,431评论 0 7
  • 今日立春。 2017年2月3日,农历正月初七。年后上班第一天。 而我,正是在这一天,准备做一项改变自己的行动,努力...
    薛静春阅读 415评论 8 4