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实现的几个小loading效果
Sep 27 HTML / CSS
CSS3制作苹果风格键盘特效
Feb 26 HTML / CSS
基于html和CSS3制作酷炫的导航栏
Sep 23 HTML / CSS
用CSS3的box-reflect来制作倒影效果
Nov 15 HTML / CSS
socket.io 和canvas 实现的共享画板功能
May 22 HTML / CSS
html5 乒乓球(碰撞检测)实例二
Jul 25 HTML / CSS
Html5定位终极解决方案
Feb 05 HTML / CSS
Html5之webcoekt播放JPEG图片流
Sep 22 HTML / CSS
前端水印的简单实现代码示例
Dec 02 HTML / CSS
css3 实现文字闪烁效果的三种方式示例代码
Apr 25 HTML / CSS
html+css实现分层金字塔的实例
Jun 02 HTML / CSS
CSS Transition通过改变Height实现展开收起元素
Aug 07 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实现登陆验证码(类似条行码状)
2006/10/09 PHP
PHP 内存缓存加速功能memcached安装与用法
2009/09/03 PHP
JavaScript创建命名空间的5种写法
2014/06/24 PHP
discuz目录文件资料汇总
2014/12/30 PHP
PHP实现自动对图片进行滚动显示的方法
2015/03/12 PHP
PHP SPL标准库中的常用函数介绍
2015/05/11 PHP
php连接MSsql server的五种方法总结
2018/03/04 PHP
用js遍历 table的脚本
2008/07/23 Javascript
JS 的应用开发初探(mootools)
2009/12/19 Javascript
JS获取html对象的几种方式介绍
2013/12/05 Javascript
JavaScript中的Repaint和Reflow用法详解
2015/07/27 Javascript
JavaScript函数的调用以及参数传递
2015/10/21 Javascript
简述JavaScript提交表单的方式 (Using JavaScript Submit Form)
2016/03/18 Javascript
Angular JS数据的双向绑定详解及实例
2016/12/31 Javascript
Bootstrap模态框使用详解
2017/02/15 Javascript
JavaScript中的普通函数和箭头函数的区别和用法详解
2017/03/21 Javascript
你知道JavaScript Symbol类型怎么用吗
2020/01/08 Javascript
状态机的概念和在Python下使用状态机的教程
2015/04/11 Python
python pandas消除空值和空格以及 Nan数据替换方法
2018/10/30 Python
python 3.3 下载固定链接文件并保存的方法
2018/12/18 Python
在Python 字典中一键对应多个值的实例
2019/02/03 Python
如何使用Python多线程测试并发漏洞
2019/12/18 Python
django Layui界面点击弹出对话框并请求逻辑生成分页的动态表格实例
2020/05/12 Python
Django在Model保存前记录日志实例
2020/05/14 Python
python如何调用字典的key
2020/05/25 Python
CSS3下的渐变文字效果实现示例
2018/03/02 HTML / CSS
Skyscanner阿联酋:全球领先的旅游搜索平台
2017/11/25 全球购物
Guess欧洲官网:美国服饰品牌
2019/08/06 全球购物
中学门卫岗位职责
2013/12/26 职场文书
《假如》教学反思
2014/04/17 职场文书
节能减耗标语
2014/06/21 职场文书
教师党员先进性教育自我剖析材料思想汇报
2014/09/24 职场文书
单位政审意见范文
2015/06/04 职场文书
四群教育工作总结
2015/08/10 职场文书
安全生产学习心得体会
2016/01/18 职场文书
MySQL中你可能忽略的COLLATION实例详解
2021/05/12 MySQL