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动画过渡实现鼠标跟随导航效果
Feb 08 HTML / CSS
纯CSS3实现滚动的齿轮动画效果
Jun 05 HTML / CSS
纯css3制作网站后台管理面板
Dec 30 HTML / CSS
CSS3中的display:grid,网格布局介绍
Oct 30 HTML / CSS
css3实现文字首尾衔接跑马灯的示例代码
Oct 16 HTML / CSS
HTML5所有标签汇总及标签意义解释
Mar 12 HTML / CSS
使用HTML5进行SVG矢量图形绘制的入门教程
Feb 19 HTML / CSS
详解Canvas 跨域脱坑实践
Nov 07 HTML / CSS
HTML5实现无刷新修改URL的方法
Nov 14 HTML / CSS
canvas实现烟花的示例代码
Jan 16 HTML / CSS
关于解决iframe标签嵌套问题的解决方法
Mar 04 HTML / CSS
基于HTML十秒做出淘宝页面
Oct 24 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
Sony CFR 320 修复改造
2020/03/14 无线电
十天学会php之第九天
2006/10/09 PHP
php获取某个目录大小的代码
2008/09/10 PHP
PHP的基本常识小结
2013/07/05 PHP
ThinkPHP之M方法实例详解
2014/06/20 PHP
PHP 反射(Reflection)使用实例
2015/05/12 PHP
详解thinkphp中的volist标签
2018/01/15 PHP
找到一点可怜的关于dojo资料,谢谢作者!
2006/12/06 Javascript
Javascript引用指针使用介绍
2012/11/07 Javascript
JS实现切换标签页效果实例代码
2013/11/01 Javascript
javascript中的Base64、UTF8编码与解码详解
2015/03/18 Javascript
javascript异步处理工作机制详解
2015/04/13 Javascript
jQuery中extend函数详解
2015/07/13 Javascript
如何利用AngularJS打造一款简单Web应用
2015/12/05 Javascript
不得不分享的JavaScript常用方法函数集(下)
2015/12/25 Javascript
JavaScript模板引擎Template.js使用详解
2016/12/15 Javascript
基于Vue.js实现tab滑块效果
2017/07/23 Javascript
nodeJs实现基于连接池连接mysql的方法示例
2018/02/10 NodeJs
Vue $emit $refs子父组件间方法的调用实例
2018/09/12 Javascript
深入浅出 Vue 系列 -- 数据劫持实现原理
2019/04/23 Javascript
extjs4图表绘制之折线图实现方法分析
2020/03/06 Javascript
JavaScript变量Dom对象的所有属性
2020/04/30 Javascript
PyQt5每天必学之组合框
2018/04/20 Python
Django REST framework视图的用法
2019/01/16 Python
python根据字典的键来删除元素的方法
2020/08/16 Python
Django视图类型总结
2021/02/17 Python
html5的pushstate以及监听浏览器返回事件的实现
2020/08/11 HTML / CSS
Sephora丝芙兰澳洲官方网站:国际知名化妆品购物
2016/10/27 全球购物
学习两会精神心得范文
2014/03/17 职场文书
捐书活动总结
2014/05/04 职场文书
人力资源管理专业自荐书
2014/07/07 职场文书
员工趣味活动方案
2014/08/27 职场文书
向国旗敬礼活动小结
2014/09/27 职场文书
新农村建设指导员工作总结
2015/08/13 职场文书
MySQL into_Mysql中replace与replace into用法案例详解
2021/09/14 MySQL
Oracle中日期的使用方法实例
2022/07/07 Oracle