探究background-position属性中的百分比值的使用_CSS教程_CSS_网页制作

来源:脚本之家  责任编辑:小易  

background-position如何影响背景图的展示

这两天在项目中替换首页图片的时候,发现了一个问题,之前的样式设置的是background-position:center,当页面缩小或者放大时背景图显示的区域也会变化,现在改成left top后,页面如何变化大小图片位置都没动。这一想,也不对啊,background-position:center难道不是从元素居中位置才显示背景图吗,为什么还是占满了全部元素区域?这个center到底指的是背景图的center还是元素的center?

background-position属性

background-position为一个集合属性,设置的是背景图的起始位置,分别为background-position-x和background-position-y,可用的值有left,right,top,bottom,以及固定像素值和百分比值。

background-position-x: left (等价于0%) background-position-x: right (等价于100%) background-position-y: top (等价于0%) background-position-x: bottom (等价于100%)

抛开固定像素值定位,那么这次主要探究百分比值对背景图位置的影响,百分比值正常来看应该是相对于元素的宽高的百分比,然而实际表现却不是如此。

设置为百分比值的实际情况

注:此次用作背景元素容器的元素宽高设置为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百分比值内容请搜索真格学网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持真格学网!


  • 本文相关:
  • 探究background-position属性中的百分比值的使用
  • 在vue-cli中使用css-loader实现css module
  • 浅谈解决space-evenly兼容性问题的两种方法
  • 纯css实现div悬浮的示例代码(固定位置)
  • 详解如何解决position:fixed固定定位偏移问题
  • 探索css属性*-gradient的实用价值
  • 使用纯 css 实现滚动阴影效果
  • css仿苹果平滑开关按钮效果
  • css实现弹窗上下左右居中且背景透明锁定窗口效果
  • css 利用 position + margin 实现固定盒子横向纵向居中的方法
  • 关于css的background-position属性用百分比的意思,
  • CSS里面背景图像使用background-position定位显示...
  • css中background-position以百分比作值时的参考点是谁
  • js控制css background-position属性只能用具体的数...
  • css中background-position以百分比作值时的参考点是谁
  • CSS background-position的定义和用法
  • background-position这个在CSS里什么意思?
  • 怎么用css中background属性截图?
  • CSS background-position 定义背景具体位置如何计算?
  • background-position在css中有什么用?
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全主页网页制作csscss教程百分比值探究background-position属性中的百分比值的使用css实现弹窗上下左右居中且背景透明锁定窗口效果css 利用 position + margin 实现固定盒子横向纵向居中的方法css教程css3div+css教程web标准教程浏览器兼容教程css布局实例css控制ul li 的样式详解(推荐)html设置超链接字体颜色和点击后的字体颜色div水平垂直居中的完美解决方案css设置各种中文字体如雅黑、黑体、宋体、楷体等等css 文本字体颜色设置方法(css color)css 漂亮搜索框美化代码css自定义select下拉选择框的样式(不用其他标签模拟)css圆角效果 -webkit-border-radius(css3中border-radcss 中的background:transparent到底是什么意思有什么css 首行缩进两个文字探究background-position属性中的百分比值的使用在vue-cli中使用css-loader实现css module浅谈解决space-evenly兼容性问题的两种方法纯css实现div悬浮的示例代码(固定位置)详解如何解决position:fixed固定定位偏移问题使用纯 css 实现滚动阴影效果探索css属性*-gradient的实用价值css仿苹果平滑开关按钮效果css实现弹窗上下左右居中且背景透明锁定窗口效果css 利用 position + margin 实现固定盒子横向纵向居
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved