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代码实现switch滑动开关按钮效果
Aug 30 HTML / CSS
CSS3制作翻转效果_动力节点Java学院整理
Jul 11 HTML / CSS
CSS3 网页下拉菜单代码解释 中文翻译
Feb 27 HTML / CSS
css3的transition属性详解
Dec 15 HTML / CSS
CSS3实现线性渐变用法示例代码详解
Aug 07 HTML / CSS
详解HTML5 LocalStorage 本地存储
Dec 23 HTML / CSS
Html5实现单张、多张图片上传功能
Apr 28 HTML / CSS
HTML5资源预加载(Link prefetch)详细介绍(给你的网页加速)
May 07 HTML / CSS
Data URI scheme详解和使用实例及图片base64编码实现方法
May 08 HTML / CSS
解决Firefox下不支持outerHTML问题代码分享
Jun 04 HTML / CSS
html5录音功能实战示例
Mar 25 HTML / CSS
HTML速写之Emmet语法规则的实现
Apr 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 得到根目录的 __FILE__ 常量
2008/07/23 PHP
PHP实现长文章分页实例代码(附源码)
2016/02/03 PHP
php上传大文件设置方法
2016/04/14 PHP
Yii框架连接mongodb数据库的代码
2016/07/27 PHP
web前端开发也需要日志
2010/12/09 Javascript
JQuery 选择器、过滤器介绍
2011/02/14 Javascript
Javascript代码在页面加载时的执行顺序介绍
2013/05/03 Javascript
JavaScript中的cacheStorage使用详解
2015/07/29 Javascript
基于Bootstrap使用jQuery实现简单可编辑表格
2016/05/04 Javascript
jquery的ajax提交form表单的两种方法小结(推荐)
2016/05/25 Javascript
Ext JS框架程序中阻止键盘触发回退或者刷新页面的代码分享
2016/06/07 Javascript
jquery配合.NET实现点击指定绑定数据并且能够一键下载
2016/10/28 Javascript
jQuery 全选 全不选 事件绑定的实现代码
2017/01/23 Javascript
基于Bootstrap漂亮简洁的CSS3价格表(附源码下载)
2017/02/28 Javascript
webpack打包后直接访问页面图片路径错误的解决方法
2017/06/17 Javascript
基于JavaScript实现多级菜单效果
2017/07/25 Javascript
jquery获取链接地址和跳转详解(推荐)
2017/08/15 jQuery
node.js多个异步过程中判断执行是否完成的解决方案
2017/12/10 Javascript
JS求Number类型数组中最大元素方法
2018/04/08 Javascript
Nuxt.js之自动路由原理的实现方法
2018/11/21 Javascript
微信小程序实现购物页面左右联动
2019/02/15 Javascript
基于vue+echarts数据可视化大屏展示的实现
2020/12/25 Vue.js
如何在JavaScript中正确处理变量
2020/12/25 Javascript
[51:36]Optic vs Newbee 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/18 DOTA
python实现用户登陆邮件通知的方法
2015/07/09 Python
详解python的ORM中Pony用法
2018/02/09 Python
浅析Python __name__ 是什么
2020/07/07 Python
python爬虫用mongodb的理由
2020/07/28 Python
Pycharm自带Git实现版本管理的方法步骤
2020/09/18 Python
中国医药集团国药在线:国药网
2017/02/06 全球购物
预订全球最佳旅行体验:Viator
2018/03/30 全球购物
Pharmacy Online中文直邮网站:澳洲大型药房
2020/06/27 全球购物
爱心捐款感谢信
2015/01/20 职场文书
python爬不同图片分别保存在不同文件夹中的实现
2021/04/02 Python
详解Python中*args和**kwargs的使用
2022/04/07 Python
高通2023 年将发布高性能PC处理器
2022/04/29 数码科技