专注收集记录技术开发学习笔记、技术难点、解决方案
网站信息搜索 >> 请输入关键词:
您当前的位置: 首页 > HTML/CSS

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

发布时间:2010-05-20 14:01:29 文章来源:www.iduyao.cn 采编人员:星星草
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 }
利用魔术精灵选择器智能输出

比如hover,active,focus,target等。利用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;

友情提示:
信息收集于互联网,如果您发现错误或造成侵权,请及时通知本站更正或删除,具体联系方式见页面底部联系我们,谢谢。

其他相似内容:

热门推荐: