记得当时面试的时候被问到对css sprite的认识,现在详细的解析一下,这个用法,加深一下映像,总没啥坏处。
一、什么是css sprite?用css sprite有什么好处?
css sprite,也有人叫css精灵、css雪碧,说的通俗一点儿,就是将css中定义的多个背景图片合成到一张,以减少http请求数。目前很多网站都在使用,算不上新技术,但是也很好用。
最大的优点就是可以减少http的请求数,一般情况下,合成后得到的图片,比单张图片相加后所得的数据量,要小得多。另一个喜爱大型 sprite 的理由是可以利用一些 sprite 生成器来简单得生成 sprite。
二、经典的例子——社交网站分享功能
<ul class="share"> <li>分享到:</li> <li><a class="renren" href="#" title="分享到人人网">人人网</a></li> <li><a class="kaixin" href="#" title="分享到开心网">开心网</a></li> <li><a class="sina" href="#" title="转帖到新浪微博">新浪微博</a></li> <li><a class="douban" href="#" title="分享到豆瓣">豆瓣</a></li> <li><a class="more" href="#" title="添加到更多">更多</a></li> </ul>
ul.share li{float:left;} ul.share li a{display:block;width:25px;height:25px;text-indent:-9999px;} a.renren{background:url(../images/share.gif) 0 0 no-repeat;} a.kaixin{background:url(../images/share.gif) -25px 0 no-repeat;} a.sina{background:url(../images/share.gif) -50px 0 no-repeat;} a.douban{background:url(../images/share.gif) -75px 0 no-repeat;} a.more{background:url(../images/share.gif) -100px 0 no-repeat;}分享功能是css精灵最常用的一种展示形式,不过上边的代码也有不完全的地方,css代码应该使用background-position这样可以增强代码的可维护性。此外图像替换时,如果使用text-indent属性之后,如果用户禁用图片,那么相对应的文字链接也就看不到了。在firefox下还需要为元素设置overflow:hidden,否则点击元素的时候,会出现超长的虚线框。
相关推荐
**CSS3最全手册概述** CSS3(Cascading Style Sheets Level 3)是Web样式表语言的最新版本,用于描述HTML或XML(包括如SVG、MathML等各种XML方言)文档的呈现。CSS3不仅增加了许多新的功能和选择器,还对现有的CSS...
概述这个包提出了一个基于构建的 CSS 精灵,该是根据免费许可提出的。 要了解有关“CSS sprites”概念的更多信息,请参阅。用法安装这个包是一个“独立”的 CSS 框架。 要使用它,您只需要从 GitHub 获取其源代码并...
【CSS工具概述】 在Web开发领域,CSS(Cascading Style Sheets)是不可或缺的一部分,它负责定义网页的样式和布局。对于软件工程师来说,拥有一套实用的CSS工具能够极大地提高工作效率,提升网页设计的质量。以下是...
**CSS3概述** CSS(层叠样式表)是用于描述HTML或XML(包括如SVG、MathML等各种XML方言)文档的外观和格式的样式语言。CSS3是CSS的最新版本,引入了许多新的特性和改进,包括更丰富的选择器、多列布局、边框和背景...
#### 一、项目概述 本篇文章主要介绍了如何使用HTML和CSS技术构建一个具有实际意义的文章展示页面。文章展示页是网络上非常常见的一种页面形式,其核心组成部分主要包括文章标题区域和文章正文区域。本文将详细介绍...
申请文件资产/ CSS / app.css index.html js / Boot.js Game.js gamecontroller.js main.js phaser.js phaser.min.js Preload.js概述www/js/app.js是游戏的入口,它定义并引导了以下场景(或状态): :设置游戏场景...
famflags是一组国家标志CSS Sprite。 如今,如果您可以依靠不错的Unicode / Emoji支持,则应该只使用。 方式与历史 如果您只想使用图像,请查看下载链接。 如果要构建自己的存储库,请克隆存储库并运行make。 请...
8. **CSS性能优化**:通过选择器优化、减少重绘和回流、使用CSS Sprite技术等方法,提升VikJobs的页面加载速度和性能。 9. **语义化HTML**:良好的HTML结构对于SEO和可访问性至关重要。VikJobs的HTML代码可能遵循...
2. **性能优化**:减少HTTP请求数量,合并CSS文件,利用CSS Sprite技术整合图像,以及使用适当的CSS3特性如渐进增强,都能提升kasafin-kudi的加载速度。 3. **语义化HTML**:配合语义化的HTML元素使用CSS,如、、等...
6. **性能优化**:通过合理的CSS选择器优化、减少重绘和回流,以及使用CSS Sprite、雪碧图技术减少HTTP请求,提升页面加载速度。 在`smed-sistemas-main`目录中,可能包含以下内容: - HTML 文件:定义了页面的...
3. **Sprite**:精灵,用于显示2D图像,是游戏中的基本图形元素。 4. **Director**:导演,负责管理游戏的运行,包括屏幕更新、时间控制、场景切换等。 5. **EventDispatcher**:事件调度器,处理和分发游戏中的各种...
在本案例中,"cv"可能是指一个关于创建或设计简历的项目,而"CSS"标签则暗示了这个项目可能涉及到使用层叠样式表(Cascading Style Sheets)来美化和格式化简历的呈现效果。接下来,我们将深入探讨与简历制作和CSS...
#### 一、规范目的概述 本文档的核心目的是为了提升团队协作效率,确保代码质量,以及建立一套统一的编码风格规范。规范文档一经确认,所有前端开发人员都应按照该规范执行前台页面开发工作。文档内容会持续更新和...
6. **性能优化**:通过CSS最小化、雪碧图(Sprite Sheets)和异步加载等技巧,提升网站的加载速度和性能。 **Mouthful-main文件夹分析** "Mouthful-main"很可能是项目的主要源代码目录,包含以下组件: 1. **HTML...
克里斯平和桑树:书呆子前端(NAT) NAT(Nerd评估测试)是Nerdery候选人面试... :从CSS源文件生成Sprite Sheet。 最佳且不同的Sprite工作表方法。 gulp :图像比较工具,逐像素进行比较。 用于整页设计回归测试 g
##概述此工作流基于Gulp任务,可以使您的Jade,Sass,Javascript等...文件编译器变得如此酷... 注意:如果您不知道什么是Gulp以及如何使用它,我建议您去观看并从此视频中学习:)( ) ##安装打开您的Termanial,...
【中国象棋游戏开发概述】 中国象棋,作为一款深受中国人民喜爱的传统智力游戏,具有丰富的策略性和娱乐性。在IT行业中,将这种经典棋类游戏移植到数字平台,如前端应用,是技术与文化传承的结合。这款"挑战智商"的...
6.1.5 css属性值选择符 / 234 6.1.6 伪类选择符 / 235 6.1.7 扩展选择器 / 248 6.1.8 ext.domquery的使用方法 / 249 6.1.9 ext js选择器的总结 / 252 6.2 获取单一元素:ext.dom.element / 252 6.2.1 从错误...
例如,合并CSS和JS文件、使用雪碧图(sprite sheet)技术可以减少网络请求次数。 【总结】 HTML作为网页开发的核心,配合CSS和JavaScript,能创建功能丰富、交互性强的网页。不断进化的HTML5提供了更多工具和功能...