雪碧图就是很多张小图片合并成一张大图片,以减少HTTP请求,从而提升加载速度。有很多软件可以合并雪碧图,但通常不太容易维护,使用compass生成雪碧图应该算是非常方便的方法了,可以轻松的生成雪碧图,而且易维护。

安装sass与compass

安装sass可以参考这里

安装完sass以后,使用下面命令安装compass:

> gem install compass

配置环境

进入项目目录,使用下面命令初始化项目:

> compass init

该命令会在当前目录中生成一些文件:

- sass
|-- ie.scss
|-- print.scss
|-- screen.scss - stylesheets
|-- ie.sss
|-- print.sss
|-- screen.sss config.rb

其中sass与stylesheets文件夹中的文件基本上没什么用。config.rb配置文件中的内容一般不需要改动,也可以根据需要修改。

合并图片

在当前目录下创建一个images的文件夹放置所有图片,然后在images文件夹中创建一个icons文件夹放置需要合并的图片。在sass文件夹中创建一个icons.scss文件,在文件中写入:

@import "icons/*.png";
@include all-icons-sprites;

然后,命令行执行compass compile命令,合并图片工作就已完成。images文件夹中多了一张icons-*******.png的图片。在stylesheets文件夹中会生成一个icons.css的文件:

.icons-sprite, .icons-car-icon, .icons-card-icon, .icons-hand-icon, .icons-light, .icons-pan, .icons-title, .icons-watch-icon, .icons-wheel, .icons-wheel1 {
background-image: url('/images/icons-sd6ae4306cd.png');
background-repeat: no-repeat;
} .icons-car-icon {
background-position: 0 0;
} .icons-card-icon {
background-position: 0 -124px;
} .....

自定义类名

可以看到上面生成的css文件中的类名都是自动生成的,在实际应用中通常并不会使用上面的默认类名,这时需要自定义类名:

@import "icons/*.png";
.car-icon {
@include icons-sprite(car-icon);
}

注意:@include icons-sprite(car-icon)不要写成@include icons-sprites(car-icon),否则会有意想不到的结果。@include all-icons-sprites这句可以去掉,就不会生成默认的类名了。上面输出的结果为:

.icons-sprite, .car-icon {
background-image: url('/images/icons-sd6ae4306cd.png');
background-repeat: no-repeat;
} .car-icon {
background-position: 0 0;
}

雪碧地图(Sprite maps)

可以使用雪碧地图取代上面的@import,如下:

$icons: sprite-map("icons/*.png", $spacing: 8px, $layout: horizontal);
.car-icon {
background-image: sprite-url($icons);
width: image-width(sprite-file($icons, car-icon));
height: image-height(sprite-file($icons, car-icon));
background-position: sprite-position($icons, car-icon);
background-repeat: no-repeat;
}

结果:

.car-icon {
background-image: url('/images/icons-s6844bf5750.png');
width: 242px;
height: 116px;
background-position: 0 0;
background-repeat: no-repeat;
}

上面使用了很多compass内置的方法:

sprite-url($icons); //获取合并后雪碧图的url;
sprite-file($icons, $name); //获取目标icon;
image-width(); //获取图片宽度;
image-height(); //获取图片高度;
sprite-position($icons, $name); //获取图片坐标

设置图片尺寸

之前生成的css文件中并没有设置图片的尺寸,一般情况下是需要设置的。可以通过下面的设置设置图片尺寸:

$icons-sprite-dimensions: true;

输出结果:

.car-icon {
background-position: 0 0;
height: 116px;
width: 242px;
}

上面的设置会为每张图图片添加尺寸,也可以指定为某张图片添加尺寸:

.car-icon {
@include icons-sprite(car-icon);
width: icons-sprite-width(car-icon);
height: icons-sprite-height(car-icon);
}

布局方式

布局方式就是生成的雪碧图中小图片的排列方式。compass提供了四中排列方法:vertical、horizontal、diagonal和smart。默认排列方式是vertical。

使用方法就是在icons.scss文件中加上:

$icons-layout: "vertical";

其他方式用法一样。

下面是四种布局生成的图片:

垂直排列

水平排列

斜向排列

智能排列

设置间距

通常,我们会在图片与图片之间设置一定的间距,添加一下代码:

$icons-spacing: 8px;

上面为图片之间设置了8px的间距。

总结:

上面简单介绍了使用compass制作雪碧图。在使用生成的css文件时会有一个问题:在PC端我们可以直接使用生成的css文件,但在移动端并不能直接使用,因为移动端需要缩放图片以适应不同分辨率的屏幕。然而生成的css文件的宽高都是使用绝对单位px的,这样在移动端并不适用。由于篇幅原因,我会在下一篇介绍在移动端怎样使用compass生成的雪碧图。

使用sass与compass合并雪碧图(一)的更多相关文章

  1. 使用sass与compass合并雪碧图(二)

    上一篇文章介绍了怎样使用compass合并雪碧图,生成的icons.css文件中单位是px,PC端可以直接在html文件中使用,但在移动端,我们需要根据不同分辨率的屏幕,来缩放图片大小,显然使用px单 ...

  2. Sass和Compass制作雪碧图

    1.安装好了sass与compass之后设置一个配置文件 2.新增一个雪碧图文件夹用来存放将要合并的图片例如color文件夹 3.@import命令引用 .Compass看到@import指令的参数为 ...

  3. compass做雪碧图

    由于最近没什么时间好好写博文,我把用sass做雪碧图的关键点贴出来方便自己记忆: config.rb注释 # Set this to the root of your project when dep ...

  4. 使用Compass制作雪碧图

    遇见好的文章,笔者也会转载.但是正所谓好记性不如烂笔头,单纯的拿来主义也不如自己的亲自实践.所以每次需要转载的文章,我都会自己敲一遍,中间加入一些自己的思考. 这篇文章转载自:http://www.h ...

  5. 利用compass制作雪碧图

    compass是什么?是sass一款神奇插件,具体教程,我还是推荐阮一峰sass,compass教程,简单清晰明了. 用ps制作雪碧图,工作效率太低了.用compass来制作,方便很多.下图的用com ...

  6. compass Sprites 雪碧图 小图片合成[Sass和compass学习笔记]

    demo 源码 地址 https://github.com/qqqzhch/webfans 什么是雪碧图? CSS雪碧 即CSS Sprites,也有人叫它CSS精灵,是一种CSS图像合并技术,该方法 ...

  7. compass与css sprite(雪碧图)

    什么是css sprite? css sprite,中文叫雪碧图,也有人喊CSS精灵,就是一种背景拼合的技术,然后通过background-position来显示雪碧图中需要显示的图像. MDN相关链 ...

  8. sass制作雪碧图

    1.配置文件config.rb http_path = "../../../" css_dir = "Content/css" sass_dir = " ...

  9. compass框架的sprite雪碧图的用法简要

    ---恢复内容开始--- **简介** CSS SPRITE 即 CSS雪碧,即是将诸多图片合成一张图片,然后使用CSS 的background和background-position属性渲染. 这样 ...

随机推荐

  1. 使用Charles进行移动APP抓包分析

    一.简介 Charles是目前最强大最流行的http抓包调试工具,Mac.Unix.Windows各个平台都支持.特别是做APP开发,调试与服务端的通信,Charles是必备工具. 目前Charles ...

  2. CentOS中配置VNC Server

    环境:CentOS 6.4 1.安装tigervnc-server及相关软件 首先检查系统中是否安装tigervnc-server安装包 rpm -qa tigervnc-server 如果没有就直接 ...

  3. 实现一个自定义event事件,包括on ,off,trigger,once

    on监听事件,off取消事件 ,trigger触发事件,once只执行一次 class Event { constructor() { this.handlers = {};//记录所有的事件以及处理 ...

  4. pyhon 列表的增删改查

    li = ['alex', 'wusir', 'egon', '女神', 'taibai'] l1 = li[2] print(l1) #增加 append() 增加到最后 insert(index, ...

  5. mysql远程连接权限设置

    今儿有位同事提出,一套MySQL 5.6的环境,从数据库服务器本地登录,一切正常,可是若从远程服务器访问,就会报错, ERROR 1045 (28000): Access denied for use ...

  6. 泰坦尼克(Titanic)生存因素可视化

    数据来源: kaggle 分析工具:Python 3.6 & jupyter notebook 附上数据:链接: https://pan.baidu.com/s/1D7JNvHmqTIw0Oo ...

  7. AFO预定

    妈耶 数论题都不会 推不出式子 题解都看不懂 还是思维jiang化了 布星了 吃枣药丸 祝yyb进队 祝zsy进队 祝鸡贼进队

  8. P3674 小清新人渣的本愿

    P3674 小清新人渣的本愿 一道妙不可言的题啊,,, 一看就知道是个莫队 考虑求答案 1号操作就是个大bitset,动态维护当前的bitset \(S\),把能取哪些值都搞出来,只要\(S\ and ...

  9. ASP.NET Application Life Cycle

    The table in this topic details the steps performed while an XAF ASP.NET application is running. Not ...

  10. WHO ARE YOU?--writeup

    TIPS:广东强网杯线上题 总结知识点:BASE64,ROT13 0x00 Base64 什么是Base64? Base64编码原理 其用途 什么是Base64? Base64是一种基于64个可打印字 ...