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 相关文章推荐
css动画效果之animation的常用样式
Mar 09 HTML / CSS
详解CSS3 用border写 空心三角箭头 (两种写法)
Sep 29 HTML / CSS
发现两个有趣的CSS3动画效果
Aug 14 HTML / CSS
基于CSS3的CSS 多栏(Multi-column)实现瀑布流源码分享
Jun 11 HTML / CSS
基于CSS3实现图片模糊过滤效果
Nov 19 HTML / CSS
CSS3 animation实现逐帧动画效果
Jun 02 HTML / CSS
使用HTML5 Canvas API绘制弧线的教程
Mar 22 HTML / CSS
HTML5 常见面试题之PC端和移动端区别介绍
Jan 22 HTML / CSS
小程序canvas中文字设置居中锚点
Apr 16 HTML / CSS
浅析HTML5页面元素及属性
Jan 20 HTML / CSS
CSS3点击按钮圆形进度打钩效果的实现代码
Mar 30 HTML / CSS
html+css实现分层金字塔的实例
Jun 02 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文件操作实现代码分享
2011/09/01 PHP
探讨捕获php错误信息方法的详解
2013/06/09 PHP
php中AES加密解密的例子小结
2014/02/18 PHP
PHP 图片合成、仿微信群头像的方法示例
2019/10/25 PHP
自适应高度框架 ----属个人收藏内容
2007/01/22 Javascript
基于Jquery的动态创建DOM元素的代码
2010/12/28 Javascript
实现动画效果核心方式的js代码
2013/09/27 Javascript
浅谈JavaScript Math和Number对象
2015/01/26 Javascript
关于事件mouseover ,mouseout ,mouseenter,mouseleave的区别
2015/10/12 Javascript
基于Bootstrap实现城市三级联动
2017/11/23 Javascript
如何用input标签和jquery实现多图片的上传和回显功能
2018/05/16 jQuery
VUE预渲染及遇到的坑
2018/09/03 Javascript
vue移动端项目缓存问题实践记录
2018/10/29 Javascript
详解js获取video任意时间的画面截图
2019/04/17 Javascript
详解javascript中var与ES6规范中let、const区别与用法
2020/01/11 Javascript
js实现批量删除功能
2020/08/27 Javascript
JavaScript 事件代理需要注意的地方
2020/09/08 Javascript
Nest.js散列与加密实例详解
2021/02/24 Javascript
python继承和抽象类的实现方法
2015/01/14 Python
Python3.6基于正则实现的计算器示例【无优化简单注释版】
2018/06/14 Python
这可能是最好玩的python GUI入门实例(推荐)
2019/07/19 Python
Python实现基于socket的udp传输与接收功能详解
2019/11/15 Python
Python绘制二维曲线的日常应用详解
2019/12/04 Python
Python常驻任务实现接收外界参数代码解析
2020/07/21 Python
用Python实现童年贪吃蛇小游戏功能的实例代码
2020/12/07 Python
Python爬虫+Tkinter制作一个翻译软件的示例
2021/02/20 Python
纯CSS3实现3D旋转书本效果
2016/03/21 HTML / CSS
关于box-sizing的全面理解
2016/07/28 HTML / CSS
详解CSS3+JS完美实现放大镜模式
2020/12/03 HTML / CSS
类如何去实现接口
2013/12/19 面试题
在校生钳工实习自我鉴定
2013/09/19 职场文书
远程培训的心得体会
2014/09/01 职场文书
西安兵马俑导游词
2015/02/02 职场文书
学者《孟子》名人名言
2019/08/09 职场文书
java中用float时,数字后面加f,这样是为什么你知道吗
2021/09/04 Java/Android
Spark SQL 2.4.8 操作 Dataframe的两种方式
2021/10/16 SQL Server