background-position百分比原理详解


Posted in HTML / CSS onMay 08, 2021

今天帮别人调代码时,看到一个样式:

background-position: 50% 0;
background-size: 100% auto;

对background-size:100% auto,意思是背景图片宽度为元素宽度*100%,高度等比缩放。

对background-position很自然的以为百分比是根据父元素宽度计算的,但background-position真的不是,它有一套自己的原理。下面详细介绍。

一、等价写法

在看各类教程时有以下等价写法:

  • 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%.

那么为什么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】:

background-position百分比原理详解

背景图在容器中居中。

<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>

效果都是让背景图片居中

background-position百分比原理详解

如上通过设置百分比和关键字能实现背景图居中,如果要实现通过具体值来设置图片居中该设置多少?

根据上面公式:

x=(容器的宽度-背景图宽度)*x百分比=(300px-200px)*50%=50px;

y=(容器的高度-背景图高度)*y百分比=(300px-200px)*50%=50px;

即设置background-postion:50px 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 百分比内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

 
HTML / CSS 相关文章推荐
CSS3五个技巧给你的网站带来出色的效果
Apr 02 HTML / CSS
今天学到的CSS最新技术(与图片背景相关)
Dec 24 HTML / CSS
用CSS3的box-reflect设置文字倒影效果的方法讲解
Mar 07 HTML / CSS
简单掌握CSS3中resize属性的用法
Apr 01 HTML / CSS
css3中less实现文字长阴影(long shadow)
Apr 24 HTML / CSS
突破canvas语法限制 让他支持链式语法
Dec 24 HTML / CSS
html5指南-6.如何创建离线web应用程序实现离线访问
Jan 07 HTML / CSS
html5 Canvas画图教程(3)—canvas出现1像素线条模糊不清的原因
Jan 09 HTML / CSS
实例教程 利用html5和css3打造一款创意404页面
Oct 20 HTML / CSS
html5写一个BUI折叠菜单插件的实现方法
Sep 11 HTML / CSS
HTML5实现无刷新修改URL的方法
Nov 14 HTML / CSS
解析CSS 提取图片主题色功能(小技巧)
May 12 HTML / CSS
不要在HTML中滥用div
css display table 自适应高度、宽度问题的解决
CSS 新特性 contain控制页面的重绘与重排问题
CSS3新特性详解(五):多列columns column-count和flex布局
css position fixed 左右双定位的实现代码
Apr 29 #HTML / CSS
css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效
CSS3实现的侧滑菜单
You might like
php函数之子字符串替换&amp;#65279; str_replace
2011/03/23 PHP
php array_pop()数组函数将数组最后一个单元弹出(出栈)
2011/07/12 PHP
Laravel定时任务的每秒执行代码
2019/10/22 PHP
Javascript String对象扩展HTML编码和解码的方法
2009/06/02 Javascript
js中判断文本框是否为空的两种方法
2011/07/31 Javascript
常见JS效果之图片减速度滚动实现代码
2011/12/08 Javascript
Extjs4 GridPanel 的几种样式使用介绍
2013/04/18 Javascript
javascript scrollTop正解使用方法
2013/11/14 Javascript
JS数组的常见用法实例
2015/02/10 Javascript
微信小程序 实现拖拽事件监听实例详解
2016/11/16 Javascript
Redux 和 Mobx的选择问题:让你不再困惑!
2017/09/18 Javascript
详解Vue中使用Echarts的两种方式
2018/07/03 Javascript
jquery 时间戳转日期过程详解
2019/10/12 jQuery
vue项目实现图片上传功能
2019/12/23 Javascript
JS数组push、unshift、pop、shift方法的实现与使用方法示例
2020/04/29 Javascript
vue实现公共方法抽离
2020/07/31 Javascript
关于vue 项目中浏览器跨域的配置问题
2020/11/10 Javascript
[01:04:06]DOTA2上海特级锦标赛A组资格赛#2 Secret VS EHOME第一局
2016/02/26 DOTA
列举Python中吸引人的一些特性
2015/04/09 Python
Python中defaultdict与lambda表达式用法实例小结
2018/04/09 Python
Python实现计算圆周率π的值到任意位的方法示例
2018/05/08 Python
Python获取昨天、今天、明天开始、结束时间戳的方法
2018/06/01 Python
详解Python if-elif-else知识点
2018/06/11 Python
anaconda中更改python版本的方法步骤
2019/07/14 Python
python递归法解决棋盘分割问题
2019/07/17 Python
kafka-python 获取topic lag值方式
2019/12/23 Python
在Pytorch中计算自己模型的FLOPs方式
2019/12/30 Python
Python selenium使用autoIT上传附件过程详解
2020/05/26 Python
详解Python中list[::-1]的几种用法
2020/11/16 Python
Django-celery-beat动态添加周期性任务实现过程解析
2020/11/26 Python
html5的input的required使用中遇到的问题及解决方法
2018/04/24 HTML / CSS
爱尔兰电脑、家电和家具购物网站:Buy It Direct
2019/07/09 全球购物
摩飞电器俄罗斯官方网站:Morphy Richards俄罗斯
2020/07/30 全球购物
电子信息工程专业求职信
2014/06/28 职场文书
幼儿园体操比赛口号
2015/12/25 职场文书
Python基础详解之描述符
2021/04/28 Python