background-position百分比原理_html/css_WEB-ITnose
程序员文章站
2022-04-11 18:26:14
...
今天帮别人调代码时,看到一个样式: top left, left top 等价于 0% 0%. top, top center, center top 等价于 50% 0%. right top, top right 等价于 100% 0%. left, left center, center left 等价于 0% 50%. center, center center 等价于 50% 50%. right, right center, center right 等价于 100% 50%. bottom left, left bottom 等价于 0% 100%. bottom, bottom center, center bottom 等价于 50% 100%. bottom right, right bottom 等价于 100% 100%.
background-position: 50% 0;background-size: 100% auto;
对background-size:100% auto,意思是背景图片宽度为元素宽度*100%,高度等比缩放。详情可见css3 background。
对background-position很自然的以为百分比是根据父元素宽度计算的,但background-position真的不是,它有一套自己的原理。下面详细介绍。
一、等价写法在看各类教程时有以下等价写法:
那么为什么left,top就等价于0% 0%,right bottom等价于100% 100%呢?
二、background-position百分比计算公式
background-postion:x y;x:{容器(container)的宽度?背景图片的宽度}*x百分比,超出的部分隐藏。y:{容器(container)的高度?背景图片的高度}*y百分比,超出的部分隐藏。
有了这个公式,就很容易理解百分百写法了,推算一下也就很容易理解上面各类等价写法了。
三、举例1、background-position:center center等价于background-position:50% 50%等价于background-position:?px ?px
例子中用到背景图如下【尺寸:200px*200px】:
背景图在容器中居中。
效果都是让背景图片居中
如上通过设置百分比和关键字能实现背景图居中,如果要实现通过具体值来设置图片居中该设置多少?
根据上面公式:
x=(容器的宽度-背景图宽度)*x百分比=(300px-200px)*50%=50px;
y=(容器的高度-背景图高度)*y百分比=(300px-200px)*50%=50px;
即设置background-postion:50px 50px;
测试一下:
效果同样居中。
推荐阅读
-
background-position百分比原理详解
-
请教一下width 百分比float的写法_html/css_WEB-ITnose
-
css background-position属性_html/css_WEB-ITnose
-
前端小tips,纯css3各方向小三角的制作原理_html/css_WEB-ITnose
-
line-height属性值为百分比和数字乘积因子的区别_html/css_WEB-ITnose
-
浏览器工作原理_html/css_WEB-ITnose
-
同样的样式,同百分比控制img的高度,在安卓下可以,为什么在ios下就不行呢?_html/css_WEB-ITnose
-
报告一个IE很奇葩的滚动条问题--百分比计算宽度为浮点数时的滚动条显示异常_html/css_WEB-ITnose
-
css实现小三角(原理)_html/css_WEB-ITnose
-
CSS3圆形百分比进度条的实现原理_html/css_WEB-ITnose