html 自适应单位vw,CSS单位em、rem、vh和vw等及CSS3的calc()以及line-height百分比

本文介绍了CSS中的自适应单位,如vw, vh, em, rem, vmin, vmax以及ch和ex。详细解释了它们的用法和特点,并探讨了在不同场景下的应用。同时,讨论了css3的calc()函数用于动态计算长度,以及line-height百分比的使用规则。通过实例解析了各种单位和计算方式在实际布局和字体调整中的作用。" 110254123,10293965,STM32F407串口DMA配置与UART基础,"['STM32F407', 'UART', 'DMA', 'HAL库', '嵌入式开发']

css单位我们常用的是px,也即是像素。随着网页开发自适应的要求,css3新增了许多单位,rem、vw和vh、vmin和vmax、ch和ex等。

em

做前端的应该对em不陌生,不是什么罕见的单位,是相对单位,参考物是父元素的font-size,具有继承的特点。如果字体大小是16px(浏览器的默认值),那么 1em = 16px。

不过,这样使用很复杂,很难很好的与px进行对应,因此,前端开发的前辈们总结了一个经验:

body{font-size:62.5%;

}

那么,这样之后 1em = 10px 在布局等使用的时候好换算了很多。

百分比

百分比相信大家更不会陌生了,百分比一般宽泛的讲是相对于父元素,但是并不是十分准确。

1、对于普通定位元素就是我们理解的父元素

2、对于position: absolute;的元素是相对于已定位的父元素(offset parent)

3、对于position: fixed;的元素是相对于 ViewPort。(viewport:可视窗口,也就是浏览器的window那么大。)

rem

rem支持IE9及以上,意思是相对于根元素html(网页),不会像em那样,依赖于父元素的字体大小,而造成混乱。使用起来安全了很多。

html{font-size:62.5%; /**10 ÷ 16 × 100% = 62.5% 1rem = 10px **/}body{1.4rem; *1.4 × 10px = 14px *h1{font-size:2.4rem; *2.4 × 10px = 24px**/}

这样整个网页都会比较统一!不会造成混乱!

rem单位确实好处蛮多的,它是相对于根节点,让我们整个网站单位可以统一。还可以让我们的字体更好的自适应网站的大小。但是,你用过了就知道,它会出现一个问题:

用Chrome浏览器打开你做的网站的时候,有时候会出现字体很大的情况。但是刷新一下页面就好了。

之所以会出现这种情况,原因是因为我们为了计算方便,将原本默认1rem=16px修改1rem=10px。因此,我们在html中通常做了如下设置:

*/}

但是呢,Chrome浏览器有时候会忽略了html的设置。于是在初始化页面的时候,出现了上面字体过大的情况,本来1.6rem应该渲染成16px的字体,却被渲染成了16*1.6=25.6px大小了。

你仔细研究会发现,出现字体过大的“元素”,通常是没有设置font-size的,元素的font-size是继承根目录的,因此,字体会变大。

因此,最佳的一种解决方案是:

在你要展现的文字父级或者其本身设置font-size

第二种解决方案:

我们在页面中添加style样式,给body设置font-size

例如把下面的代码放到 head 里面:

}

>

vh 和 vw

IE10+ 和现代浏览器都支持这两个单位。

vw Viewport宽度, 1vw等于viewport宽度的1%

vh Viewport高度, 1vh等于viewport高的的1%

vw和vh会随着viewport变化自动变化,再也不用js控制全屏了。

甚至有些人丧心病狂的字体大小都用vw和vh控制,来达到字体和viewport大小同步的效果。

vmin和vmax

IE10+ 和现代浏览器都已经支持vmin

webkit浏览器之前不支持vmax,新版已经支持,所有现代浏览器已经支持,但是IE 全部不支持vmax

vmin vw和vh中比较 小 的值

vmax vw和vh中比较 大的值

这两个属性也会随着viewport变化

ch和ex

IE9+ 和现代浏览器都已经支持,这两个单位时根据 当前font-family的相对单位。

ch 字符0的宽度

ex 小写字符x的高度

如图:

316628342b26fa3c5778675e8a47a840.jpg

当font-family改变的时候这两个单位的值也会变化,不同字体表现的样式不一样。

css3的calc()

浏览器支持IE9+、FF4.0+、Chrome19+、Safari6+

calc()语法非常简单,就像我们小时候学加 (+)、减(-)、乘(*)、除(/)一样,使用数学表达式来表示:

.container{width:calc(expression);

}

例如:

calc(100% - 20px);//注:减号前后要有空格,否则很可能不生效!!}

兼容写法:

width:90%;写给不支持calc()的浏览器*/-moz-calc(100% - (10px + 5px) * 2);-webkit-calc(100% - (10px + 5px) * 2);calc(100% - (10px + 5px) * 2);

}

line-height百分比

line-height百分比在面试中可能经常问到。例如你知道line-height:120%和line-height:1.2的区别吗?

现在就说一下行高带单位和不带单位的区别,例如下面的例子:

line-height:26px; 表示行高为26个像素

line-heigth:120%;表示行高为当前字体大小的120%

line-height:2.6em; 表示行高为当前字体大小的2.6倍

带单位的行高都有继承性,其子元素继承的是计算值,如父元素的字体大小为14px,定义行高line-height:2em;则计算值为 28px,不会因其子元素改变字体尺寸而改变行高。(例如:父元素14px,子元素12px,那么行高就是28px,子元素虽然字体是12px,行高还是父元素的行高)

line-height:2.6;表示行高为当前字体大小的2.6倍

不带单位的行高是直接继承,而不是计算值,如父元素字体尺寸为14px,行高line-height:2;子元素字体为12px,不需要再定义行高,他默认的行高为24px。(例如:子元素12px,他的行高是24px,不会继承父元素的28px)

一个完整的例子:

htmlheadcharset="utf-8"/>

name="description"content=""="keywords"/>

.parent_01font-size14px;line-height150%backgroundgreenpadding10px}.parent_021.5.parent_03.children26pxbackgroundredbodydivclass="parent_01">

="children">行高测试div>

br/><="parent_02"="parent_03">

其中,parent_01,parent_02,parent_03下面的文字效果如图所示:

4577ff79cca9dc4d3030519c95ee8dd1.png

如上图,结果分析:

parent_01:有百分比的children继承了父级元素14*1.5=21px;

parent_02:没有百分比,不带单位的是自己的1.5倍,也就是26*1.5=39px;

parent_03:带百分比,但是父元素没有设置字体大小,但是父元素继承了浏览器默认的字体大小16px,即时16*1.5=24px

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

jb51ccc.jpg

小编个人微信号 jb51ccc

喜欢与人分享编程技术与工作经验,欢迎加入编程之家官方交流群!

### %(百分比百分比单位是相对于父元素的尺寸来计算的。在不同的属性中,它所参照的父元素尺寸不同。例如,在设置宽度时,`width: 50%;` 表示元素的宽度是其父元素宽度的 50%;在设置字体大小时,`font-size: 150%;` 表示元素的字体大小是其父元素字体大小的 150%。 ### vw(视口宽度) `vw` 是相对于视口宽度而定的单位,1vw 相当于视口宽度的 1/100。比如,若视口宽度为 1000px,那么 1vw 就等于 10px,设置 `width: 50vw;` 则元素宽度为 500px。它常用于创建与视口宽度成比例的布局,能使元素在不同宽度的屏幕上自适应显示 [^2]。 ### vh(视口高度) `vh` 相对于视口的高度而定,1vh 相当于视口高度的 1/100。假设视口高度为 800px,1vh 就是 8px,设置 `height: 20vh;` 元素高度即为 160px。同样可用于创建随视口高度自适应的布局 [^2]。 ### em `em` 是相对单位,相对于元素的字体大小。如果元素自身没有设置字体大小,则继承父元素的字体大小。例如,父元素字体大小为 16px,子元素设置 `font-size: 1.5em;`,那么子元素的字体大小就是 24px(16×1.5)。当使用 `em` 作为其他属性(如宽度、边距等)的单位时,也是基于元素的字体大小计算的。在 CSS 时,可在 `body` 选择器中声明 `Font-size = 62.5%`,将原来的 px 数值除以 10,然后换上 `em` 作为单位,同时要重新计算那些被放大的字体的 `em` 数值,避免字体大小的重复声明 [^1]。 ### rem `rem` 是相对于根元素(即 `html` 元素)的字体大小的单位。无论元素嵌套层级如何,只要设置了 `rem` 单位,其大小都以根元素的字体大小为基准。例如,根元素字体大小设置为 16px,设置 `width: 2rem;`,元素宽度就是 32px(16×2)。为了方便计算,常通过设置根元素字体大小使 1rem 等于 10px [^2]。 ```css /* 设置根元素字体大小 */ html { font-size: 62.5%; /* 使 1rem = 10px */ } /* 使用 rem 单位设置元素宽度 */ div { width: 20rem; /* 宽度为 200px */ } /* 使用 em 单位设置字体大小 */ p { font-size: 1.5em; /* 假设父元素字体大小为 16px,则 p 元素字体大小为 24px */ } /* 使用 vw vh 单位设置元素尺寸 */ section { width: 50vw; /* 宽度为视口宽度的 50% */ height: 30vh; /* 高度为视口高度的 30% */ } /* 使用百分比单位设置元素宽度 */ article { width: 80%; /* 宽度为父元素宽度的 80% */ } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值