(三)Sass和Compass--制作精灵图片
2015-05-20 10:54
155 查看
6.1 精灵的工作原理
// 将各种图片合并到一张图片里面,并在不同的状态下改变背景图片的位置;6.2 精灵的重要性
// 压缩图片的内存;// 减少HTTP请求
6.2.3 Compass处理精灵方案
// 1.让Compass指向一个精灵的文件夹;// 2.告诉Compass撰写精灵CSS;
// 3.编译样式表;
6.3 用Compass制作精灵
6.3.1 创建一个精灵地图
@import "compass/utilities/sprites"; // 精灵图片控件; @import "Icon/*.png"; // Icon文件夹位于images文件夹内并包含所有精灵图片; // 生成精灵图片位于images文件夹内;并生成编译后的CSS; CSS: .Icon-sprite { // 自动生成的类命名; background-image: url('/images/Icon-s040daee5af.png'); background-repeat: no-repeat; }
6.3.2 引入精灵并生成CSS
1.all-sprites精灵混合器 Sass: @include all-Icon-sprites; // 为整个精灵地图撰写所有必要的CSS; CSS: // 生成内容; .Icon-sprite, .Icon-index1, .Icon-index2, .Icon-index3, .Icon-index4, .Icon-index5 { background-image: url('/images/Icon-s040daee5af.png'); // 所有的相关类都引用此图片; background-repeat: no-repeat; } .Icon-index1 { background-position: 0 0; } ... .Icon-index5 { background-position: 0 -560px; } // 使用@extend继承精灵的样式 Sass: .add-button { @extend .Icon-index1} // 这种方法会生成更少的CSS; CSS: .Icon-index1, .add-button { // 直接叠加了一个类,比较方便; background-position: 0 0; }
2.single-sprite精灵混合器 Icon-sprite($name); // 输出一个独立命名精灵的CSS; $name:单独图片的名字(index1); Sass: .add-button2 { @include Icon-sprite(index5); } CSS: .add-button2 { background-position: 0 -560px; // 与index5对应的图片的位置; }
6.4 配置Compass精灵
6.4.1 自定义精灵地图
// 可以自定义一个精灵地图或通过其配置变量有针对性地定义精灵;// <map>:存放精灵的文件名;
// <sprite>:某个单独的精灵图片的名字;
// 以下配置的所有变量需在导入精灵("@include all-Icon-sprites")之前被定义;
1.配置精灵图之间的间距 $<map>-spacing:Xpx; // 设置所有精灵图之间的间距为Xpx; $<map>-<sprite>-spacing:Xpx; // 设置某个精灵图的间距; Sass: $Icon-spacing:4px; // 所有图片的间距为4px; $Icon-index1-spacing:12px; // index1图片的间距为12px;
2.设置精灵的重复性 $<map>-repeat:no-repeat/repeat-x; // 默认值是no-repeat;设置为repeat-x可以使其X轴平铺; $<map>-<sprite>-repeat:no-repeat/repeat-x; // 设置单个图片的重复属性; Sass: $Icon-index2-repeat:repeat-x; // index2图片在精灵图片里边横向平铺;
3.设置精灵的位置 $<map>-position:Xpx; // 垂直向右(水平向下)移动Xpx距离; $<map>-<sprite>-position:Xpx; Sass: $Icon-positioin: 10px; // 所有图片向右10px;
4.设置精灵地图的布局 $<mpa>-layout: vertical(垂直)/horizontal(水平)/diagonal(对角线)/smart(产生最小的空白区域); // 默认布局是vertical; $Icon-layout:horizontal; // 在引入sprites模块之前定义;
5.清除过期的精灵地图 $<map>-clean-up:true/false;
6.4.2 自定义精灵的CSS
1.输出精灵的尺寸 $<map>-sprite-height($name); // 得到某个精灵图片的高度; $<map>-sprite-width($name); $<map>-sprite-dimensions:true/false; // 为精灵地图中的每个精灵自动输出尺寸; Sass: .next { @include Icon-sprite(index2); width:Icon-sprite-width(index2);// 得到精灵图片的大小; } CSS: .next { background-position: -10px -150px; width: 140px; // 生成的图片大小; }
2.精灵的基础类 // Compass可以方便地通过生成一个基础类为每个精灵应用普通样式; $<map>-sprite-base-class:".class-name"; // 当使用全部精灵或单独精灵的混合器时,Compass会输出一个精灵的基础类;并且其选择器还会串联所有设置了background-image属性的选择器; // 每个精灵地图的基础类都以其文件夹的名字命名; Sass: $Icon-sprite-base-class: ".Icon"; .Icon { // 设置精灵的CSS基础类; overflow: hidden; width:Icon-sprite-width(index1); } CSS: .Icon, .Icon-index1, .Icon-index2, .Icon-index3, .Icon-index4, .Icon-index5 { overflow: hidden; width: 140px; }
3.魔术精灵选择器 $disable-magic-sprite-selectors:true/false; // 魔术精灵选择器是默认开启的,也就是说Compass在精灵时会根据以"_hover"/"_active"或"_target"结尾的名字自动输出CSS的:hover/:active和:target伪选择器; // 在Icon文件夹内添加index4_hover.png之后会自动生成关于index-4:hover的类及相关代码; CSS: .Icon-index4 { background-position: 0 -420px; } .Icon-index4:hover, .Icon-index4.index4-hover { background-position: 0 -560px; }
6.5 驾驭精灵辅助器
6.5.1 创建精灵地图
// 之前的"@import 'Icon/*.png'",不仅创建了一个精灵地图,还为精灵地图和每个精灵设置了混合器和变量;1.sprite-map辅助器 $Icon:sprite-map("Icon/*.png",$layout:smart); // 它会创建一个智能布局的精灵地图,并把精灵地图的图片URL赋值给$Icon变量;
2.sprite-map辅助器--设置单个精灵 $Icon:sprite-map("Icon/*.png",$index2-spacing:5px);
6.5.2 撰写精灵的CSS
// 在Compass为你生成精灵地图之后,仍需要写出每个精灵的CSS;1.sprite辅助器 sprite($map,$sprite,[$offset-x],[$offset-y]); // $map:精灵基础类; $sprite:单个图片名,用于定位背景图片; // sprite辅助器需要精灵地图/精灵的名字以及可选的偏移坐标; Sass: $Icon:sprite-map("Icon/*.png",$layout:smart); // 精灵基础类的一个优点就是只需要赋值一次背景图片(把路径复制到变量中); .next { background:sprite($Icon,index2) no-repeat; } // 这仅仅会输出背景属性,而不会成为一个精灵的基础类或其他任何不需要的CSS; CSS: .next { background: url('/images/Icon-s6558f78e4f.png') 0 -140px no-repeat; }
2.设置精灵的位置 // 为了移除重复的背景图片,你可以用sprite-position辅助器或sprite-background-position混合器取代sprite辅助器; Sass: $Icon:sprite-map("Icon/*.png"); // 辅助器创建精灵地图; .sprite-base { background:$Icon no-repeat; }// 引入精灵地图; .next { @extend .sprite-base; // @extend引用; background-position:sprite-position($Icon, index2); // 设置background-position属性; // sprite-position:辅助器,用于定位图片位置; // $Icon:变量,引入精灵图片路径; // index2:定位精灵图片index2位置的参数; } CSS: .sprite-base, .next { background: url('/images/Icon-sb501daeae5.png') no-repeat; } .next { background-position: 0 -140px; }
3.设置精灵的尺寸--sprite-dimensisons混合器 // 它需要精灵地图和精灵的名字,并输出经过测量的尺寸; Sass: $Icon:sprite-map("Icon/*.png"); // 辅助器创建精灵地图; .sprite-base { background:$Icon no-repeat; }// 引入精灵地图; .add { @extend .sprite-base; @include sprite-background-position($Icon,index3); // 精灵图片定位辅助器; @include sprite-dimensions($Icon,index3); }
6.6 小结
// 1.从远程服务器加载大量图片对性能的影响以及精灵图片如何作为重要方法解决高流量网站问题;// 2.Compass如何完全自动化处理精灵,并探索了配置及控制Compass生成精灵地图和CSS的几种方式;
相关文章推荐
- compass 制作精灵图
- 【Sass中级】使用Sass和Compass制作雪碧图
- Sass和Compass制作雪碧图
- 005_HTML制作炫酷登录界面(CSS精灵图、背景图片局部显示)
- 使用compass更高效的编辑css --- 图片精灵
- compass Sprites 雪碧图 小图片合成[Sass和compass学习笔记]
- Android中9patch图片格式(xx.9.png)介绍与制作详解
- 如何在Ubuntu的下制作GIF图片
- iOS中制作一张水印图片
- LICEcap方便快捷制作gif图片的工具
- 前端的精灵图制作以及精灵图定位
- VC制作使用图片做为背景的对话框
- CSS3制作精美的iphone电话图标,不使用图片
- 使用图片精灵优化前端 减少http请求
- Sencha Touch 自定义主题1: Sass & Compass 安装
- 鼠标移至图片从模糊变清晰的效果制作
- 高通LCD开机图片制作步骤(kernel部分)
- cocos2d-x使用TexturePacker打包图片及使用生成的plist文件创建精灵动画
- 精灵动画 制作动画效果
- 调查问卷如何制作图片调查