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中border-image的使用
Jul 18 HTML / CSS
用CSS3的box-reflect设置文字倒影效果的方法讲解
Mar 07 HTML / CSS
CSS3过渡transition效果实例介绍
May 03 HTML / CSS
浅谈css3中calc在less编译时被计算的解决办法
Dec 04 HTML / CSS
详解CSS3中的box-sizing(content-box与border-box)
Apr 19 HTML / CSS
值得收藏的HTML5资源(学习html5的朋友可以收藏下)
Jul 20 HTML / CSS
html5 Canvas画图教程(3)—canvas出现1像素线条模糊不清的原因
Jan 09 HTML / CSS
利用HTML5画出一个坦克的形状具体实现代码
Jun 20 HTML / CSS
详解HTML5中的manifest缓存使用
Sep 09 HTML / CSS
推荐10个HTML5响应式框架
Feb 25 HTML / CSS
使用placeholder属性设置input文本框的提示信息
Feb 19 HTML / CSS
使用CSS自定义属性实现骨架屏效果
Jun 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使用goto实现自动重启swoole、reactphp、workerman服务的代码
2020/04/13 PHP
jquery 学习笔记 传智博客佟老师附详细注释
2020/09/12 Javascript
html中table数据排序的js代码
2011/08/09 Javascript
JavaScript动态改变HTML页面元素例如添加或删除
2014/08/10 Javascript
javascript精确统计网站访问量实例代码
2015/12/19 Javascript
如何利用模板将HTML从JavaScript中抽离
2016/10/08 Javascript
基于jQuery的checkbox全选问题分析
2016/11/18 Javascript
详解angular用$sce服务来过滤HTML标签
2017/04/11 Javascript
javascript深拷贝、浅拷贝和循环引用深入理解
2018/05/27 Javascript
详解webpack2异步加载套路
2018/09/14 Javascript
js前端面试之同步与异步问题详解
2019/04/03 Javascript
Layui带搜索的下拉框的使用以及动态数据绑定方法
2019/09/28 Javascript
Vue computed 计算属性代码实例
2020/04/22 Javascript
python django集成cas验证系统
2014/07/14 Python
python3 实现一行输入,空格隔开的示例
2018/11/14 Python
Django之模型层多表操作的实现
2019/01/08 Python
python文档字符串(函数使用说明)使用详解
2019/07/30 Python
matplotlib 对坐标的控制,加图例注释的操作
2020/04/17 Python
一款简洁的纯css3代码实现的动画导航
2014/10/31 HTML / CSS
使用css3实现的tab选项卡代码分享
2014/12/09 HTML / CSS
HTML5是否真的可以取代Flash
2010/02/10 HTML / CSS
使用纯HTML5编写一款网页上的时钟的代码分享
2015/11/16 HTML / CSS
海信商城:海信电视、科龙空调、容声冰箱官方专卖
2017/02/07 全球购物
东方通信股份有限公司VC面试题
2014/08/27 面试题
.net开发工程师面试题
2014/02/25 面试题
本科生职业生涯规划书范文
2014/01/21 职场文书
基层党员公开承诺书
2014/05/29 职场文书
2014年秋季开学典礼主持词
2014/08/02 职场文书
法院干警四风问题个人对照检查材料思想汇报
2014/10/07 职场文书
2014年党支部工作总结
2014/11/13 职场文书
新教师2015年度工作总结
2015/07/22 职场文书
2016年校园重阳节广播稿
2015/12/18 职场文书
大学学生会主席竞选稿怎么写?
2019/08/19 职场文书
python基于scrapy爬取京东笔记本电脑数据并进行简单处理和分析
2021/04/14 Python
分享3个非常实用的 Python 模块
2022/03/03 Python
PyTorch device与cuda.device用法
2022/04/03 Python