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系列教程:背景图片(背景大小和多背景图) 应用说明
Dec 19 HTML / CSS
CSS3实现时间轴效果
Jul 11 HTML / CSS
结合 CSS3 transition transform 实现简单的跑马灯效果的示例
Feb 07 HTML / CSS
html5使用html2canvas实现浏览器截图的示例
Aug 31 HTML / CSS
HTML5 通信API 跨域门槛将不再高、数据推送也不再是梦
Apr 25 HTML / CSS
html5跨域通讯之postMessage的用法总结
Nov 07 HTML / CSS
阻止移动设备(手机、pad)浏览器双击放大网页的方法
Jun 03 HTML / CSS
整理HTML5移动端开发的常用触摸事件
Apr 15 HTML / CSS
浅谈html5标签css3的常用样式
Oct 20 HTML / CSS
canvas探照灯效果的示例代码
Nov 30 HTML / CSS
CSS预处理框架——Stylus
Apr 21 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求小于1000的所有水仙花数的代码
2012/01/10 PHP
在smarty中调用php内置函数的方法
2013/02/07 PHP
php反射应用示例
2014/02/25 PHP
ThinkPHP自定义函数解决模板标签加减运算的方法
2015/07/03 PHP
laravel5.4利用163邮箱发送邮件的步骤详解
2017/09/22 PHP
Mac下快速搭建PHP开发环境步骤详解
2019/05/05 PHP
PHP Beanstalkd消息队列的安装与使用方法实例详解
2020/02/21 PHP
如何判断图片地址是否失效
2007/02/02 Javascript
索趣科技的答案
2007/02/07 Javascript
关于viewport,Ext.panel和Ext.form.panel的关系
2009/05/07 Javascript
jQuery DOM操作小结与实例
2010/01/07 Javascript
jqPlot 基于jquery的画图插件
2011/04/26 Javascript
javascript 另一种图片滚动切换效果思路
2012/04/20 Javascript
Javascript基础_简单比较undefined和null 值
2016/06/14 Javascript
AngularJS extend用法详解及实例代码
2016/11/15 Javascript
jQuery实现动态添加tr到table的方法
2016/12/26 Javascript
详解React项目的服务端渲染改造(koa2+webpack3.11)
2018/03/19 Javascript
js中对象和面向对象与Json介绍
2019/01/21 Javascript
Vue结合后台导入导出Excel问题详解
2019/02/19 Javascript
vue如何限制只能输入正负数及小数
2019/07/04 Javascript
Typescript的三种运行方式(小结)
2019/09/18 Javascript
JavaScript Array对象使用方法解析
2019/09/24 Javascript
[01:11:11]Alliance vs RNG 2019国际邀请赛淘汰赛 败者组BO1 8.20.mp4
2020/07/19 DOTA
Python 时间操作例子和时间格式化参数小结
2014/04/24 Python
介绍Python中内置的itertools模块
2015/04/29 Python
python 内置模块详解
2019/01/01 Python
python用WxPython库实现无边框窗体和透明窗体实现方法详解
2020/02/21 Python
线程的基本概念、线程的基本状态以及状态之间的关系
2012/10/26 面试题
应届生煤化工求职信
2013/10/21 职场文书
办公室内勤岗位职责范本
2013/12/09 职场文书
学校创先争优活动总结
2014/08/28 职场文书
领导干部作风整顿剖析材料
2014/10/11 职场文书
团队拓展训练感想
2015/08/07 职场文书
JS数组方法some、every和find的使用详情
2021/10/05 Javascript
2022年四月新番
2022/03/15 日漫
python数字图像处理之图像的批量处理
2022/06/28 Python