`

css中使用一张图片显示多个背景

 
阅读更多

  不知你有没有经历过,看到网页上的一些漂亮的图标,如列表图标,于是把它下载,打开一看,竟然不是我们下载的单个图标,而是一张大图,上面集合着许多小图标!
这里便使用了CSS中一张图片显示多个背景的方法
这些小图标为什么不是分别存储成单独的图标,而是集合放在一张图片上?这样做的目的就是减少http请求次数,节省时间和带宽。
强烈推荐使用这种方法!
当然,实现的方法是有多种,下面将通过一个例子来说一下我常使用的方法。
1、显示完整的图片

如图(1)

代码:

01 <style type="text/css">  
02 <!--  
03 .bg{ 
04 WIDTH: 181px; 
05 HEIGHT: 61px; 
06
07 .bg .logo { 
08 POSITION: relative; WIDTH: 181px; BACKGROUND: url(./logo.gif) 0px 0px; FLOAT: left; HEIGHT: 60px; 
09
10
11 --> 
12 </style>  
13 <body
14 <div class="bg"
15 <div class="logo"></div
16 </body>

关键代码:

1 POSITION: relative; WIDTH: xpx; BACKGROUND: url(image) x1px y1px; FLOAT: left; HEIGHT: ypx;

POSITION属性说明:
relative--相对定位
WIDTH--图片显示的宽度
image --背景图片(这里是图片的地址)
x1px--图片水平位置偏移量,起点为(0,0),如取负值将向反方向偏移
y1px---图片竖直位置偏移量
FLOAT--图片浮动方向,如left,right
HEIGHT--图片显示的高度

现在我们将在上面的位置为参照物显示图片不同区域。
1.1、只显示图片中的“W‘

如图(2):

图示显示部分WIDTH: 75px,HEIGHT: 60px,图片水平向左偏移3px.代码:

1 .bg .logo { 
2         
3     POSITION: relative; WIDTH: 75px; BACKGROUND: url(./logo.gif) -3px 0px; FLOAT: left; HEIGHT: 60px; 
4         
5 }

1.2、只显示图片中的一个“B“,如图(3)


图示显示部分WIDTH: 38px,HEIGHT: 60px,图片水平向左偏移78px,竖直向下偏120px,代码:

1 .bg .logo { 
2     POSITION: relative; WIDTH: 38px; BACKGROUND: url(./logo.gif) -78px 120px; FLOAT: left; HEIGHT: 60px 
分享到:
评论

相关推荐

    css3实现一个div设置多张背景图片及background-image属性实例演示

    在CSS3中,`background-image`属性极大地扩展了对背景图片处理的能力,使得在一个单一的HTML元素(如div)上设置多个背景图片成为可能。这个特性显著提高了网页设计的灵活性和创意性,减少了以往需要通过嵌套div来...

    CSS截取一张图片上的所有图标

    在本案例中,我们讨论的主题是如何利用CSS技术来从一张大的图片(Icons.gif)中截取并显示多个32×32像素大小的图标。这个过程通常被称为CSS精灵(CSS Sprites)技术,它是一种优化网页加载速度的方法,通过合并多个...

    css背景合并工具,自动生成CSS样式

    在网页设计中,有时我们需要为一个元素设置多个背景图层,例如背景色、背景图片、图案或者渐变等。手动编写这些复杂的CSS代码既耗时又容易出错。而这个工具则能快速合并和优化这些背景设置,生成简洁、高效的CSS代码...

    css背景属性案例

    案例中的页面展示了李白的《静夜思》,背景使用了一张图片,并且该图片只显示一次,不重复。 #### 四、深入理解CSS背景属性 1. **`background-color`**:当没有设置背景图片时,这个属性会显得尤为重要。例如,...

    css3鼠标滑过小图显示大图背景特效

    在实际项目中,可能会有多个小图对应同一张大图,这时可以使用CSS3的数据属性(data-attributes)来关联小图和大图。例如: ```html &lt;div class="small-image" data-large-image="large-image-url.jpg"&gt;&lt;/div&gt; ``` ...

    CSS背景颜色例子

    如果你想让多个连续的元素共享相同的背景颜色,可以使用CSS的通用选择器`*`或类选择器`.class`。例如: ```css /* 设置所有元素的背景色 */ * { background-color: lightblue; } /* 或者针对特定类 */ .myClass {...

    css3马赛克样式图片切换

    2. **背景图片与伪元素**:另一种方法是使用`::before`或`::after`伪元素,并设置`background-image`属性,通过CSS3的`background-size`控制每个马赛克单元的图片大小,`background-position`调整图片的位置,以及`...

    布纹背景CSS创意模板

    在提供的文件列表中,我们可以看到多个带有“-”后缀的HTML文件,如`index-both.htm`、`blog-single.htm`等,这些通常是不同类型的页面模板,例如首页、博客单篇文章页等。每个模板会包含对应的CSS样式,定义了页面...

    CSS3网页背景音乐动画代码.zip

    3. **精灵图(Sprite Sheets)**:为了提高性能,开发者可能会使用精灵图技术将多个小图像合并成一张大图,然后通过CSS的背景定位来显示需要的部分。这样可以减少HTTP请求,加速页面加载。 4. **媒体查询(Media ...

    css sprite示例源码

    1. 合并图像:使用图像编辑软件(如Photoshop、GIMP等)将多个小图标或背景图片拼接成一张大图。 2. 记录坐标:记录每个小图像在大图中的位置(左上角的坐标),以便在CSS中进行定位。 三、CSS Sprite的应用 1. ...

    关于图片显示问题的CSS总结

    通过将多个小图标合并到一张大图中,然后用`background-position`调整背景图像的位置来显示所需的图标。 总的来说,理解并掌握这些CSS知识点,将有助于开发者更高效地处理网页中的图片显示问题,提升网站的整体质量...

    CSS图片下载器

    4. **批量处理**:如果CSS文件中引用了多个图片,工具会一次性处理所有的下载任务,实现批量化操作。 使用"CSS图片下载器"有以下几个关键好处: 1. **节省时间**:手动下载大量图片会花费大量时间,而工具可以快速...

    jquery+css3实现图片背景全屏左右图片切换效果

    要实现全屏背景图片切换,我们首先需要在HTML中设置一个全屏的图片容器,通常是一个`div`元素,然后用CSS设置其大小为视口的100%,并设置背景图像属性,使图片充满整个容器。可以使用CSS3的`background-size`属性...

    Css Sprite Tools(CST CSS图片拼合定位工具) 1.0 

    在网页设计中,CSS Sprite(CSS精灵)是一种常见的优化网页加载速度的方法,通过将多个小图像合并成一个大图,然后利用CSS的背景定位属性来显示需要的部分,以此减少HTTP请求次数,加快页面加载速度。CST CSS图片...

    css 背景图片

    `background` 属性是一个复合属性,可以一次性设置多个背景相关的属性,包括颜色、图像、重复方式、固定方式和位置。使用这个属性可以更简洁地管理复杂的背景样式。例如: ```css section { background: #f0f0f0 ...

    css sprites图片背景优化技术

    CSS Sprites图片背景优化技术是一种常见的前端性能优化策略,它将多个小图像合并到一张大图(称为sprites图)中,然后通过CSS的background-position属性来控制显示其中的某一部分。这种方法可以显著提高网站的加载...

    css取背景位css取背景位css取背景位

    CSS Sprites是一种优化网页加载速度的方法,它将多个小图像合并到一张大图中,通过调整背景位置来显示需要的图像部分。这样减少了HTTP请求次数,提升了页面加载效率。 假设`sprites.png`包含一个导航栏的各个图标,...

    抓取网页图片,css和js

    3. CSS Sprite:将多个小图片合并成一张大图,通过定位来显示不同图片。 三、CSS图片抓取 CSS图片抓取需解析CSS文件,找出上述三种情况下的图片URL。可以使用CSS解析库,如Python的`cssselect`和`lxml`,或者...

    显示背景图片的一部分

    如果需要从大图中提取多个小图,可以使用CSS精灵图技术。通过把多个图标合并到一张大图中,然后通过调整`background-position`来显示需要的部分,减少HTTP请求,提高页面加载速度。 5. **JavaScript和CSS结合**: ...

    css精灵图像合并

    CSS精灵(CSS Sprite)是一种网页图像处理方式,它将多个小图像合并到一张大图(称为精灵图)中,然后通过CSS的背景定位技术来显示需要的部分,以此达到减少HTTP请求,提高页面加载速度的效果。这种方法在网页设计中...

Global site tag (gtag.js) - Google Analytics