css-sprite使用详解

所属分类: 网页制作 / CSS 阅读数: 2036
收藏 0 赞 0 分享

可能是最好用的雪碧图工具了,好吧,至少是我用过最好用的。

首先安装css-sprite,安装这里很坑,等我最后再说。


复制代码
代码如下:
npm install css-sprite

我是使用gulp来构建前端代码,所以还需要安装gulp和gulp-if,安装好之后就可以开始配置啦。
新建一个task:

CSS Code复制内容到剪贴板
  1. var gulp = require('gulp');   
  2. var gulpif = require('gulp-if');   
  3.   
  4. gulp.task('sprites',function(){   
  5.     gulp.src('img/icon/*.png')                  //这是要合并的图片的路径   
  6.         .pipe(sprite({   
  7.             name: 'icon',                       //定义一个名称   
  8.             style: '_icon.scss',                //这是生成的样式文件   
  9.             format'png',                      //png格式的图片   
  10.             orientation: 'left-right',          //雪碧图合并的方向,也可以设置成垂直或水平   
  11.             cssPath: '#{$icon-sprite-path}',    //雪碧图的路径变量   
  12.             template: './sprite-tpl.mustache',  //scss生成的模板   
  13.             processor: 'scss'                   //生成的样式文件的格式   
  14.         }))   
  15.         .pipe(gulpif('*.png', gulp.dest('img/'), gulp.dest('css/')));   
  16. });  

scss的模板使用mustache:

CSS Code复制内容到剪贴板
  1. {{#items}}   
  2.     ${{name}}: {{px.offset_x}} {{px.offset_y}} {{px.width}} {{px.height}};   
  3. {{/items}}   
  4.   
  5. @mixin sprite-width($sprite) {   
  6. width: nth($sprite, 3);   
  7. }   
  8.   
  9. @mixin sprite-height($sprite) {   
  10. height: nth($sprite, 4);   
  11. }   
  12.   
  13. @mixin sprite-position($sprite) {   
  14. $sprite-offset-x: nth($sprite, 1);   
  15. $sprite-offset-y: nth($sprite, 2);   
  16. background-position: $sprite-offset-x  $sprite-offset-y;   
  17. }   
  18.   
  19. @mixin sprite($sprite) {   
  20. @include sprite-position($sprite);   
  21.   
  22. @include sprite-width($sprite);   
  23. @include sprite-height($sprite);   
  24.   
  25. }   
  26.   
  27. {{#sprite}}   
  28.     {{class}} {   
  29.     background-repeatno-repeat;   
  30.     overflowhidden;   
  31.     bordernone;   
  32.     backgroundurl('{{{escaped_image}}}?v=#{$version}');   
  33.     @include inline-block();   
  34.     vertical-alignmiddle;   
  35.     font-stylenormal;   
  36.     color:$icon-font-color;   
  37.     }   
  38. {{/sprite}}   
  39.   
  40. {{#items}}   
  41.     .{{name}}{   
  42.     @include sprite(${{name}});   
  43.     }   
  44. {{/items}}  

搞定!就是那么简单。

现在只需要把图片丢到icon文件夹里面,运行下gulp sprites,就可以生成一张雪碧图icon.png和相对应的scss样式文件_icon.scss了,也可以再新建一个监听的任务,监听icon文件夹,这样就可以实时生成了。

我把_icon.scss贴出来:

CSS Code复制内容到剪贴板
  1. $icon-qq: -262px -161px 60px 60px;   
  2. $icon-email: -332px -161px 60px 60px;   
  3. $icon-skype: -5px -252px 60px 60px;   
  4. $icon-phone: -75px -252px 60px 60px;   
  5. @mixin sprite-width($sprite) {   
  6. width: nth($sprite, 3);   
  7. }   
  8.   
  9. @mixin sprite-height($sprite) {   
  10. height: nth($sprite, 4);   
  11. }   
  12.   
  13. @mixin sprite-position($sprite) {   
  14. $sprite-offset-x: nth($sprite, 1);   
  15. $sprite-offset-y: nth($sprite, 2);   
  16. background-position: $sprite-offset-x  $sprite-offset-y;   
  17. }   
  18.   
  19. @mixin sprite($sprite) {   
  20. @include sprite-position($sprite);   
  21.   
  22. @include sprite-width($sprite);   
  23. @include sprite-height($sprite);   
  24.   
  25. }   
  26. .icon {   
  27.     background-repeatno-repeat;   
  28.     overflowhidden;   
  29.     bordernone;   
  30.     backgroundurl('#{$icon-sprite-path}/icon.png?v=#{$version}');   
  31.     @include inline-block();   
  32.     vertical-alignmiddle;   
  33.     font-stylenormal;   
  34.     color:$icon-font-color;   
  35. }   
  36. .icon-qq{   
  37.     @include sprite($icon-qq);   
  38. }   
  39. .icon-email{   
  40.     @include sprite($icon-email);   
  41. }   
  42. .icon-skype{   
  43.     @include sprite($icon-skype);   
  44. }   
  45. .icon-phone{   
  46.     @include sprite($icon-phone);   
  47. }  

使用的时候只需要加上类似class="icon icon-qq",就可以了。

css-sprite的地址
现在作者已经没有更新css-sprite了,现在叫sprity,配置差不多,sprity多了一些功能,有时间再介绍。

现在说下开头说的那个坑,就是安装的问题,微软的环境很难安装成功,因为依赖lwip,需要node-gyp重新编译,我自己的电脑安装好了,但是有些同事的电脑怎么配置都安装不成功。mac下还没有尝试,估计应该没什么问题,windows的环境比较操蛋。

如果你们也遇到安装的问题,能够解决的话,麻烦告知下啦。:)

更多精彩内容其他人还在看

CSS样式分离之再分离达到精简与重用

无论是CSS的分离还是js的分离,其主要作用之一就是精简与重用,CSS本身就代表着精简与重用,CSS样式分离,我一般指的是“以单独的CSS文件将CSS样式分离出来”,此处的重用多针对不同页面的重用,就是说,一个样式文件,可以多个页面使用,这对于一些公共样式的重构是很有
收藏 0 赞 0 分享

CSS属性behavior的语法使用说明

在进行CSS网页布局的时候,我们经遇到刷新要保留表单里内容的时候,习惯的做法使用cookie,但是那样做实在是很麻烦,css中的behavior就为我们很好的解决了这个问题。今天jb51.net就向大家介绍CSS属性behavior的语法
收藏 0 赞 0 分享

网页制作中的水平居中和垂直居中解决方法集合

 在定义网页的CSS样式的时候,我们或许并不怎么用到垂直居中。
收藏 0 赞 0 分享

最常见IE的Bug及其fix修复方法

Internet Explorer – Web程序员的毒药。在IE上开发时间中有超过60%的时间是花在和IE的bug进行搏斗,让你的开发生产率严重下降。下面是一个教程,告诉你9个IE上最常见的BUG以及如何解决它们。
收藏 0 赞 0 分享

CSS常用浏览器兼容调整小结

用CSS+DIV来写网站代码的好处显而易见,这里不多说了,但由于不同浏览器对CSS的解释不统一,造成不同浏览器下页面错位的现象十分常见……
收藏 0 赞 0 分享

css firefox火狐浏览器下的兼容性问题

css firefox火狐浏览器下的兼容性问题
收藏 0 赞 0 分享

DIV+CSS 浏览器兼容性小结

在网站设计的时候,应该注意css样式兼容不同浏览器问题,特别是对完全使用DIV CSS设计的网,就应该更注意IE6 IE7 FF对CSS样式的兼容,不然,你的网乱可能出去不想出现的效果!
收藏 0 赞 0 分享

div+css 布局常识 8问

CSSer与其他IT职位一样,在找工作的时候,都会面临着面试官提出的问题,或者给出的试卷。今天jb51.net收集了常见的8条面试题目,希望对您有所帮助。
收藏 0 赞 0 分享

CSS用四种方式实现布局

CSS用四种方式实现布局
收藏 0 赞 0 分享

css 解决表格边框不显示的问题

在 IE6 中,当表格单元格中的数据为空时,边框是不显示的,在IE8中是会显示的,怎样解决这个不兼容的问题呢。
收藏 0 赞 0 分享
查看更多