background-position属性的百分比值怎样用?一文带你搞懂
Admin 2021-04-26 群英技术资讯 1822 次浏览
在替换首页图片的时候,小编发现了一个问题,之前的样式设置的是background-position:center,当页面缩小或者放大时背景图显示的区域也会变化,现在改成left top后,页面如何变化大小图片位置都没动。这一想,也不对啊,background-position:center难道不是从元素居中位置才显示背景图吗,为什么还是占满了全部元素区域?这个center到底指的是背景图的center还是元素的center?
background-position为一个集合属性,设置的是背景图的起始位置,分别为background-position-x和background-position-y,可用的值有left,right,top,bottom,以及固定像素值和百分比值。
抛开固定像素值定位,那么这次主要探究百分比值对背景图位置的影响,百分比值正常来看应该是相对于元素的宽高的百分比,然而实际表现却不是如此。
注:此次用作背景元素容器的元素宽高设置为100%,100%,且无border和padding
例1:
background-size: 100px 100px; background-position: 100% 100%;
可以看到,当background-position设置为百分之百的时候,背景图在窗口的右下角显示而不是溢出元素区域之外
接下来改变位置
例2:
background-size: 100px 100px; background-position: 50% 50%;
可以看到,现在背景图现在处于元素正中央的位置,为了证实是正中央的位置,我用了一个具有居中样式的子元素做对比,可以看到正好被子元素框柱。
通过以上两例可以看出:
当background-position设置为100% 100%的时候,图片在最右下角位置,那么此时background-position-x的像素值等于「容器元素的宽度值减去背景图的宽度」,background-position-y的像素值等于「容器元素的高度值减去背景图的高度」;
当background-position设置为50% 50%的时候,图片在元素内部居中位置,那么此时background-position-x的像素值等于「容器元素的宽度值乘以50%再减去背景图宽度的50%」,background-position-y的像素值等于「容器元素的高度值乘以50%再减去背景图高度的50%」;
如果用w代表容器元素宽度,h代表容器元素高度,bw代表背景图宽度,bh代表背景图高度,通过以上两例可以得出这么一个公式:
background-position-x: percent = (w - bw) * percent background-position-y: percent = (h - bh) * percent
在元素有padding的情况下:
padding: 100px 20px 50px 50px; background-position: 0% 0%;
可以看到背景图是在padding区域的左上角,所以background-position的百分值实际参与计算的容器元素宽高 = content + padding
如果背景图尺寸background-size设置为100% 100%的话,那么background-position不论设置为何种百分比都不会发生偏移
反之,如果背景图尺寸大于元素尺寸,设置百分比后发生的就会是负向偏移了。好了,这下终于把这个属性搞懂了,某些css属性的描述不够准确,容易引起误会,还是要自己实践才能出真知!
以上就是对background-position属性的百分比使用的介绍,相信大家对这个百分比值的使用也都有一定的了解了,想要了解更多background-position属性内容大家可以关注其他文章。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
今天给大家分享的是css让盒子水平垂直居中的方法,本文提供了八种盒子水平垂直居中方法及示例供大家参考,对新手学习和理解css水平垂直居中盒子有一定的帮助,感兴趣的朋友接下来跟随小编一起看看吧。
今天本篇文章给大家分享一个边框动画特效,看看使用CSS3如何实现边框阴影向外扩散的动画特效。我们先来看看效果图:下面我们来研究一下是怎么实现这个效果的:首先创建HTML部分,定
在用了Flex布局会发现,当水平排列后,会发现所有子项的高度都变成一样的了。这是因为Flex 布局会默认:把所有子项变成水平排列。默认不自动换行。让子项与其内容等宽,并把所有子项的高度变为最高子项的高度。这样设置背景色的时候非常不...
也就是因为这个flexbox伸缩盒布局太强大了,以至于我没在意它也是display的一个属性。要想解决这个布局问题,我们还是先了解一些基础的问题。先回顾下display有哪些属性吧:none:隐藏对象。与visibility属性的hidden值不同,其不为被隐藏的对象保留其物理空间inline:指定对象为内联元素。block:指定对象为块元素。list-i ...
今天给大家分享的是关于用CSS实现简单的波浪效果的内容,如果是纯 CSS 实现波浪效果还是比较困难的,而本文使用 CSS 实现的波浪效果的思路非常有意思,下文有有实例和详细注释供大家参考,感兴趣的朋友接下来跟随小编一起看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008