background-position还可以这样用

时间:2022-03-28 23:10:50

文章同步至微信公众号:http://mp.weixin.qq.com/s?__biz=MzAxMzgwNDU3Mg==&mid=401626453&idx=1&sn=6af07474df847d251358c4b453eaddfd#wechat_redirect

感兴趣的可以扫码关注哈:

background-position还可以这样用

background-position这个样式规则,切页面的同学应该都用过。关于其详细介绍,就不再赘述了。http://www.cnblogs.com/huazaizai/archive/2010/11/03/1867907.html这篇博客已经把background-position相关知识点描述的很详细了。

当我们把backgrund-position的值设置为百分数的时候,那么背景图的位置是怎么计算的呢?当我们指定background-position:50% 50%的时候,实际上效果等同于backgrund-position:center center。它的计算规则为:

x:{容器(container)的宽度—背景图片的宽度}*x百分比,超出的部分隐藏。

y:{容器(container)的高度—背景图片的高度}*y百分比,超出的部分隐藏。

为了清楚的表示这一点,下面举了两个栗子。

首先有这么一张图片它的宽高为:510*382

background-position还可以这样用

然后请看下面这段代码:

<!DOCTYPE html>

<html>

<head>

<style type="text/css">

.wrapper {

width: 300px;

height: 300px;

border: 2px solid red;

background-image: none;

}

</style>

</head>

<body>

<div class="wrapper"></div>

</body>

</html>

它的实际效果为

background-position还可以这样用

这正如期望的效果那样。当我们设置background-position:50% 50%的时候,运行效果就是下面的这样:

background-position还可以这样用

按照上文中的背景图的位置的计算公式x:(300-510)*50%=-105;y:(300-382)*50%=-41。

这就是我在这篇博客想表达的当background-position指定为百分数时候的情景。然而,知道这个有神马用呢?*就曾教导我们说学习的目的全在于应用。就算你理论知识掌握的再多,不知道什么地方能用到,不知道其使用场景那也是没有价值的。

在做移动端的页面的时候,我们会想办法去适配各种不同屏幕大小的屏幕。这个问题,在pc端,有些时候,同样要考虑。然而这跟background-position又有神马关系?当我们在做有些活动页面的时候,对于那些铺满一整屏的页面,backgroundposition就能派上用场了。

对于pc端的活动页面,设计师出的设计稿的大小一般都是基于1920px的宽度。其内容器往往只有1000px或1200px的大小居中。假设内容区大小为1000px入下图

background-position还可以这样用

为了让页面能在1000px宽度以上的各个浏览器中都能良好的显示,这是就backgrundposition出场的时候了。

我通常的做法就是body {background: url(bg.jpg) 50% 0 no-repeat}

.content {

widh: 1000px

margin-left: auto;

margin-right: auto;

overflow: hidden;

}

我们把设计稿的背景图做成宽度为1920宽度的背景图设计为body的背景图,位置设置为:50% 0。这样只要是屏幕在1000px像素以上都能良好显示。而且还是自适应的。这条是笔者自己的做的页面的业务需求关于backgroundposition的用法。如果您还知道其它的相关的使用场景或用法欢迎分享交流。

background-position还可以这样用的更多相关文章

  1. html5&plus;css3中的background&colon; -moz-linear-gradient 用法

    在CSS中background: -moz-linear-gradient 让网站背景渐变的属性,目前火狐3.6以上版本和google浏览器支持这个属性. background: -moz-linea ...

  2. html5&plus;css3中的background&colon; -moz-linear-gradient 用法 &lpar;转载&rpar;

    转载至-->http://www.cnblogs.com/smile-ls/archive/2013/06/03/3115599.html 在CSS中background: -moz-linea ...

  3. css3的Background新属性

    前言 CSS3中出现了几种关于背景图片的新属性:background-origin.background-clip.background-position等.之前大致了解了下,但是background ...

  4. CSS3 Gradient 渐变

    转载自:http://www.w3cplus.com/content/css3-gradient CSS3发布很久了,现在在国外的一些页面上常能看到他的身影,这让我羡慕已久,只可惜在国内为了兼容IE, ...

  5. jQuery视差滚动插件,(附原理分析,调用方法)

    演示地址:http://www.jq22.com/jquery-info1799 jquery插件,使用验证过可用. 分析源代码后总结原理:设置background样式为fixed,判断浏览器滚动距离 ...

  6. CSS3 Gradient

    CSS3CSS3发布很久了,现在在国外的一些页面上常能看到他的身影,这让我羡慕已久,只可惜在国内为了兼容IE,让这一项技术受到很大的限制,很多Web前端人员都望而止步.虽然如此但还是有很多朋友在钻研C ...

  7. CSS 笔记一(Selectors&sol; Backgrounds&sol; Borders&sol; Margins&sol; Padding&sol; Height and Width)

    Selectors/ Backgrounds/ Borders/ Margins/ Padding/ Height and Width CSS Introduction: CSS stands for ...

  8. JQuery&lowbar;过滤选择器

    一.基本过滤器 1.基本过滤器 过滤器主要通过特定的过滤规则来筛选所需的 DOM 元素,和 CSS 中的伪类的语法类似:使用冒号(:)开头. <script type="text/ja ...

  9. CSS3 线性渐变(linear-gradient) 兼容IE8&comma;IE9

    一.线性渐变在 Mozilla 下的应用     语法: -moz-linear-gradient( [<point> || <angle>,]? <stop>, ...

  10. 不用任何图片,只用简单的css写出唯美的钟表,就问你行吗?

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAGHCAIAAABJR31QAAAgAElEQVR4nOy9aXhc1ZUurPvcH7f73n ...

随机推荐

  1. Redis高可用集群方案——哨兵

    本篇文章版权归博客园和作者吴双本人共同所有,转载和爬虫请注明原文系列地址http://www.cnblogs.com/tdws/tag/NoSql/ 本人之前有篇文章,讲到了redis主从复制,读写分 ...

  2. 使用Memcache缓存mysql数据库操作的原理和缓存过程浅析

    转载自脚本之家 http://www.jb51.net/article/51831.htm  作者:忙碌的松鼠 对于大型网站如facebook,ebay等网站,如果没有Memcache做为中间缓存层, ...

  3. mysql 增、删、改、查 、函数、执行次序

    这些是最基础的部分,若果这些不能满足你的需求,可以到http://www.w3school.com.cn中查询 增删改: 增 insert into<表名>(<列名列表>(如果 ...

  4. HTML学习笔记——锚链接、pre标签、实体

    1>锚链接 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://ww ...

  5. 追溯ASP&period;NET发展史

    2000年全新平台的ASP.NET 1.0正式发布,发展速度异常惊人,2003年升级为1.1版本.ASP.NET 1.1发布之后,更加激发了Web应用程序开发人员对ASP.NET的兴趣,并且对网络技术 ...

  6. iOS - OC NSNull&Tab;&Tab;空值

    前言 @interface NSNull : NSObject <NSCopying, NSSecureCoding> 作为占据空间的一个空值,如用在数组或字典中占据一个没有任何值的空间. ...

  7. javaEE学习笔记-单例模式

    定义: 确保一个类只有一个实例,而且自行实例化并向整个系统提供这个实例. 单例模式的三要素: (1)私有的静态的成员变量 (2)私有的构造方法 (3)公共的静态的入口点方法 单例模式的分类: (1)饿 ...

  8. 表单验证插件——validate

    表单验证插件——validate 该插件自带包含必填.数字.URL在内容的验证规则,即时显示异常信息,此外,还允许自定义验证规则,插件调用方法如下: $(form).validate({options ...

  9. 几种USB控制器类型:OHCI,UHCI,EHCI,xHCI

    http://smilejay.com/2012/10/usb_controller_xhci/ 遇到过一些关于USB的东西(如下),一直没搞明白什么USB1.0/1.1/2.0/3.0之类的,当然我 ...

  10. 【EOJ Monthly 2018&period;7】【D数蝌蚪】

    https://acm.ecnu.edu.cn/contest/92/problem/D/ D. 数蝌蚪 Time limit per test: 2.0 seconds Memory limit:  ...