compass模块----Utilities----Sprites精灵图合图

css雪碧图又叫css精灵或css sprite,是一种背景图片的拼合技术。使用css雪碧图,能够减少页面的请求数、降低图片占用的字节,以此来达到提升页面访问速度的目的。但是它也有令人诟病的地方,就是拼图和后期维护的成本比较大。也正是因为这一点,导致很多开发者懒于使用css雪碧图。

配置compass项目

$ compass init

会生成相应的目录和配置文件。在images目录下建立logo目录存放需合并的图标。项目目录结构如下:

- sass
|-- icons.scss
|-- screen.scss - stylesheet - images |-- logo

 config.rb 文件配置如下:

1 http_path = "/"
2 css_dir = "stylesheets"
3 sass_dir = "sass"
4 images_dir = "images"
5 javascripts_dir = "javascripts"
6 
7 relative_assets = true    // 使用相对目录
8 line_comments = false    // 关闭行注释

合并雪碧图

输出所有雪碧图样式

新建一个文件icons.scss,在screen.scss中引入icons.scss。

在icons.scss里面引入sprites@import "compass/utilities/sprites" 

images文件里子目录logo:把所有图片放到这里。(方便将来将其和其他图片区分开来)

icons.scss文件里将logo文件引入进来: @import "logo/*.png"; (*引入logo目录下的所有文件)。

1 @import "compass/utilities/sprites";    // 加载compass sprites模块
2 @import "share/*.png";                    // 导入share目录下所有png图片
3 @include all-share-sprites;                // 输出所有的雪碧图css

生成的代码中 .logo-sprite 是雪碧图的基础类生成的每个雪碧图默认的class规则是: .目录名-图片名 。

 

调用单个雪碧图样式

1 @import "compass/utilities/sprites";    // 加载compass sprites模块
2 @import "share/*.png";                    // 导入logo目录下所有png图片
3 .main-logo{
4     @include logo-sprite("img1");
5 }

编译后的css为:

1 .logo-sprite, .main-logo {
2     background-image: url('../images/logo-sd097a30ac3.png');
3     background-repeat: no-repeat;
4 }
5 .main-logo {
6     background-position: 0 0;
7 }

利用魔术精灵选择器智能输出

比如hoveractivefocustarget等。利用compass的魔术精灵选择器我们就可以智能的合并各状态的图标,并输出对应的css。使用时,我们需要将图标按照一定的规则命名。例如:

img1.png            // 默认状态图标
img1_hover.png     // hover状态图标
img1_active.png     // active状态图标

编译后的css为:

 1 .logo-sprite, .main-logo {
 2   background-image: url('../images/logo-sd097a30ac3.png');
 3   background-repeat: no-repeat;
 4 }
 5 .main-logo {
 6   background-position: 0 0;
 7 }
 8 .main-logo:hover, .main-logo.img1-hover {
 9   background-position: -120px 0;
10 }
11 .main-logo:active, .main-logo.img1-active {
12   background-position: -60px 0;
13 }

 


调出隐藏的logo.scss命令行:

compass sprite 'images/logo/*.png'

$logo-sprite-dimensions:用来控制输出CSS的时候是否根据图片大小对我们的相应类名css属性添加一个宽和高。
$logo-layout:修改合图布局方式。

  --默认是垂直 horizontal水平的。

  --diagonal斜对角线布局的。

  --smart节省空间布局

1 $logo-sprite-dimensions: true;
2 $logo-layout: horizontal;

 

 

 
posted @ 2015-12-02 12:30  薯条_9  阅读(801)  评论(0编辑  收藏  举报