童话说说技术创业美文职业
投稿投诉
职业母婴
职场个人
历史治疗
笔记技能
美文纠纷
幽默家庭
范文作文
乐趣解密
创业案例
社会工作
新闻家居
心理安全
技术八卦
仲裁思考
生活时事
运势奇闻
说说企业
魅力社交
安好健康
传统笑话
童话初中
男女饮食
周易阅读
爱好两性

谈谈CSSSprites技术及其优化

5月17日 飞凤谷投稿
  CSSS技术对于广大的前端工程师来说应该是一点也不陌生。这个被国内开发者昵称为CSS精灵CSS雪碧的家伙到底解决了什么问题,我们又怎样合理使用这个技术呢?下面让我们详细的聊聊。
  在大家还在拨号上网的“远古时期”,由于网速的限制,页面开发者都喜欢把网页里面的图片字节数控制的非常小,往往在一个图片文件夹里散落着n多的小碎图。随着网络技术的发展,网速的提升,大家越来越重视页面的加载速度,页面效率问题,过去的那些小图便成为了前端开发者的眼中钉,因为每加载一张图片都会产生一次浏览器请求数,发起的请求数越多那么页面加载的速度也越慢。还有当页面加载时,图片一个个的零星显示,鼠标经过时候背景闪白等也都是我们不能忍受的。于是乎将页面中的背景图整合到一起,利用“backgroundimage”,“repeat”,“backgroundposition”的组合进行背景定位的技术被广泛使用与了页面构建中,这就是CSSSprites。当然CSSSprites技术也存在着维护不便,内存占用大等等的缺点。
  好了,如果我只说这些,那么这篇文章就有点太水了。前面那些只是对CSSSprites技术的一个普及。作为一个开发者我们应该对它有一个更全面的认识,挖掘深度内容,这样才能有利于我们效率开发,团队协作。
  头疼的多人拼图游戏
  使用CSSSprites,就好像玩拼图游戏一样。一张白画布,那么多图怎么放到里面去才会完美?这是个让人纠结的事。而且在实际在工作场景中,我们面临着项目开发时间紧张,UI设计图要分期提供,多人协同开发一个项目等等问题。这些问题非常容易让我们在大项目中迷失,造成CSS拼图混乱,维护及其困难的情况。
  定好规则,其实拼图也挺好玩的
  先期的准备工作
  应对一个项目后期维护成本大的问题,我们最好的解决方案就是在开始前制定一系列的规范来限制问题的产品。好的开始是成功的一半。对于CSSSprites,在项目开始前,我们要充分认识一个产品,同UI设计师做好良好的沟通,对我们未来组成我们Sprites图的各个元素有个大体的概念,比如我们的背景拼图可能包括什么。
  一个好的Sprite画布是必须的
  网页设计里面,Grid系统是必不可少的,好的Grid能解决我们很多排版问题。Grid系统同样适用于CSSSprites。我们需要创建好一个优秀的画板,剩下的工作就是将元素合理的置于画板中了。
  这张是我准备的一张CSSSprites画布,我们将在这个PSD里面组合项目中的图片。
  这张画布是由20px20px像素的格子组成。这个格子基本上由项目决定的,当我们同UI设计师沟通了解这个项目最多的为16px16图标时。我们就可以采用这种Grid尺寸为画布了。
  Sprites画布有了,接下来就是对图标进行分组了
  对于信息的归纳总结、分类是一个有意思的事情。就拿图标来说,我们就可以根据图标功能,尺寸等等作为信息维度进行归纳。其实无论怎么归纳,都是可以的,只是记得我们以一个方向作为标准就可以了。
  下图是根据微博站外某组件完成的CSSSprites
  根据设计,我们了解在这个页面,需要将图片元素根据功能分为4个维度,即微博品牌展示元素、提交按钮、操作类小按钮、提示类ICON。于是我将画布X轴坐标方向每5个格(其实完全可以10个格或者更多)划分为一个区域,每个这样一个区域的Y轴方向不再划分区域,这样做的目的是为了以后增加图标的扩展性。于是我们可以非常快速得到一个图标的坐标了。比如不可用的灰色的分享按钮X坐标520px100Y坐标720px140那么我们就取得了这个图标的位置即backgroundposition:100140px。如果抽象成为公式的话,我们设置一个单元格的宽度为变量n。X坐标值Gx,Y坐标值Gy。那么画布中的元素css背景即为:backgroundposition:GG了。
  现在图有了,怎么取图也是关键
  因为图片尽可能的被整合到一张拼图,所以我们需要在页面使用图片的位置使用空标签定位的方式将拼图所需展现的部分展示到页面中。
  。iconA{display:height:16width:16background:url(icons。png)2020}
  项目出现二期需求了,需要增加图标?
  需求总是不能控制,我们要尽可能的为未来增加图片做好打算。在刚才的例子的项目里后期产品需要增加图标,于是:
  我们可以继续在对应的图区内增加对应的图标。但是这个例子同样暴露了一个缺陷,如果新增一个按钮区域大于5n(100px),我们的图区不足以承载。这时候我们可以同产品,设计师沟通协调,商议是否可以取消过大的按钮设计。如果需求一定,那我们只能沿着X轴方向继续扩展画布。不过,我们也需要注意无限的放大一张画布,同样会造成对页面效率的影响。
  及时的制定好规范,记录好修改日志
  可能在项目的初期,我们还来不及制定合图的具体规范,在项目中我们会遇到各种各样的问题。及时的总结,维护整张CSS拼图,在拼图的PSD或者PNG(使用Fireworks)做好注释,方便他人开发。拼合好的图片提交到svn时也写明log内容,这样便日后查询。
  我们最终的目的
  其实CSSSprites经过了那么多年的演变,前端开发者不断的优化,都是为了提升页面效率,提升团队开发效率,减少开发维护成本而努力。配合最近非常流行的将CSS动态语言化(如SASSLESS等),增加入变量,继承,运算,函数等。CSSSprites会变的更好玩,会减少更多的开发维护成本。甚至我们在“面向对象”的模块开发方式中,还可以使用一个类的的同一个backgroudposition:(y)值,在不同的页面通过引用不同的图片(background属性)实现将一个页面内图片请求量进一步减少的目的。随着高级浏览器的普及我们还可以多使用CSS3属性,减少渐变背景图的使用,将纯色ICON制作成字体取代拼图等我们能更大程度上减少图片的使用量。这篇文章只是抛砖引玉。实际上还有很多关于CSSSprites的方法,还有众多的拼图生成工具。
  说了那么多,我们如果在日常的开发中,只要我们多注意总结,敢于创新,敢于制定规范,那么再小的事也能干的很漂亮,对于CSSSprites的优化就是这么一个例子,你说不是么?
  (微博UDC原创博文,欢迎转载并注明出处,欢迎订阅)
投诉 评论 转载

谈谈CSSSprites技术及其优化CSSS技术对于广大的前端工程师来说应该是一点也不陌生。这个被国内开发者昵称为CSS精灵CSS雪碧的家伙到底解决了什么问题,我们又怎样……移动应用界面设计模式搜索、排序、筛选去年年底,我们曾经学习过一篇“具有引导性的移动应用界面设计模式”,其英文原文来自O’Reilly动物园的一本新书,”MobileDesignPatternGallery”,就是……移动应用界面设计模式搜索、排序、筛选决定放假期间先不上iOSWow体验了;手头这篇译文不做完的话我心不甘。去年年底,我们曾经学习过一篇“具有引导性的移动应用界面设计模式”,其英文原文来自O’Reilly动物园的一……心理学报告丶不可思议之日常你走路的方式会透露出你的哪些性格?为什么有些人竟然会回忆起不曾发生过的事情?夏天出生的人和冬天出生的人谁运气更好?真心的笑容和虚假的笑容都打着哪些难以掩饰的烙……自适应网页设计(ResponsiveWebDesign)随着3G的普及,越来越多的人使用手机上网。移动设备正超过桌面设备,成为访问互联网的最常见终端。于是,网页设计师不得不面对一个难题:如何才能在不同大小的设备上呈现同样的网页……浅谈iOS和Android的产品交互设计:iPhone和An一、前言开发者在产品上同时覆盖iOS平台和Android平台时,则会遇到同一个功能在不同平台中界面和交互如何展现的问题。了解两个平台间的控件对应关系和异同点,对同时……PIC那些事儿在我们的生活,工作,学习过程中,社交网络已经逐渐成为未来互联网发展的趋势。今年,Facebook,Twitter,Google都是时下社交网络的热门产品,每月的用户使用量都在逐……交互设计:如何将像素点转化为全面的品牌体验编者:本文讨论了互动设计在整个品牌传播链中应该担当的角色,由于原文是一篇理论文献,行文略有晦涩,我们挑出了对互动中国读者最有用的部分翻译出来,如译文与原文有出入请以原文为主,并……让产品与用户“心有灵犀”从一个小故事说起。之前网上曾经对于“要不要做调研”这件事情有过讨论,这其中提到福特曾经这样解读自己的发明:“如果我问我的客户,他们要什么,他们的回答一定是:一匹更快的马。……腾讯微信技术总监周颢:一亿用户增长背后的架构秘密微信腾讯战略级产品,创造移动互联网增速记录,10个月5000万手机用户,433天之内完成用户数从零到一亿的增长过程,千万级用户同时在线,摇一摇每天次数过亿在技术架构上,微信是如……情感牵引和交互属性在未来手机游戏中的用户价值前不久和上海某家周刊就游戏的未来趋势提到了三个层面,其一是简单闲趣的偏单人游戏,比如TempleRun、DoodleJump之类的将长期把控手机游戏的Paid榜单(游戏邦注:事……掌控像素的虚实3月份,PhotoshopCS6Beta版(下文简称PSCS6)发布公测,有着多项惊艳的新特性,工作中整天和像素打交道,感触比较深的特性就是PSCS6支持矢量对象绘制、变换时像……
hello酷狗酷狗音乐产品体验报告产品分析每日优鲜:前置仓模式领跑生鲜到家百度地图APP产品分析报告音乐平台最新社交功能对比分析:网易云音乐VS虾米VS酷狗解析微信看一看的价值与产品细节产品分析小米有品,新消费之下的精品电商产品分析报告微信读书:社交阅读的未来趋势竞品分析“医护上门”有没有未来?产品分析丨文艺青年的精神角落,豆瓣未来何去何从?调研月子会所市场发展现状,发掘机会点产品分析你的第二大脑印象笔记产品分析:背单词到底哪家强?
宫颈炎能泡脚吗南歌子咏杨花,有寄这款茄子一出锅待客一大锅就搞定比大莫兰特被罚3。5万美元挑衅裁判使用不当语言被驱逐后未及时离场龟兔赛爬(寓言)阿娇头部受重伤被送医是什么情况?到底是怎么受伤的?母爱的色彩作文550字早熟毛豆栽培管理的技术无愁造句用无愁造句大全技术职务小狗奇奇作文650字珍惜时间精选800字作文

友情链接:中准网聚热点快百科快传网快生活快软网快好知文好找作文动态热点娱乐育儿情感教程科技体育养生教案探索美文旅游财经日志励志范文论文时尚保健游戏护肤业界