在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
今天帮别人调代码时,看到一个样式: 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】: 背景图在容器中居中。 <style type="text/css"> .wrap{ width: 300px; height: 300px; border:1px solid green; background-image: url(img/image.png); background-repeat: no-repeat; /* background-position: 50% 50%;*/ background-position: center center; } </style> <div class="wrap"> </div> 效果都是让背景图片居中 如上通过设置百分比和关键字能实现背景图居中,如果要实现通过具体值来设置图片居中该设置多少? 根据上面公式: x=(容器的宽度-背景图宽度)*x百分比=(300px-200px)*50%=50px; y=(容器的高度-背景图高度)*y百分比=(300px-200px)*50%=50px; 即设置 测试一下: <style type="text/css"> .wrap{ width: 300px; height: 300px; border:1px solid green; background-image: url(img/image.png); background-repeat: no-repeat; /* background-position: 50% 50%;*/ /* background-position: center center;*/ background-position: 50px 50px; } </style> <div class="wrap"> </div> 效果同样居中。 到此这篇关于background-position百分比原理详解的文章就介绍到这了,更多相关background-position 百分比内容请搜索极客世界以前的文章或继续浏览下面的相关文章,希望大家以后多多支持极客世界! |
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论