使用sass与compass合并雪碧图(一)
雪碧图就是很多张小图片合并成一张大图片,以减少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合并雪碧图(一)的更多相关文章
- 使用sass与compass合并雪碧图(二)
上一篇文章介绍了怎样使用compass合并雪碧图,生成的icons.css文件中单位是px,PC端可以直接在html文件中使用,但在移动端,我们需要根据不同分辨率的屏幕,来缩放图片大小,显然使用px单 ...
- Sass和Compass制作雪碧图
1.安装好了sass与compass之后设置一个配置文件 2.新增一个雪碧图文件夹用来存放将要合并的图片例如color文件夹 3.@import命令引用 .Compass看到@import指令的参数为 ...
- compass做雪碧图
由于最近没什么时间好好写博文,我把用sass做雪碧图的关键点贴出来方便自己记忆: config.rb注释 # Set this to the root of your project when dep ...
- 使用Compass制作雪碧图
遇见好的文章,笔者也会转载.但是正所谓好记性不如烂笔头,单纯的拿来主义也不如自己的亲自实践.所以每次需要转载的文章,我都会自己敲一遍,中间加入一些自己的思考. 这篇文章转载自:http://www.h ...
- 利用compass制作雪碧图
compass是什么?是sass一款神奇插件,具体教程,我还是推荐阮一峰sass,compass教程,简单清晰明了. 用ps制作雪碧图,工作效率太低了.用compass来制作,方便很多.下图的用com ...
- compass Sprites 雪碧图 小图片合成[Sass和compass学习笔记]
demo 源码 地址 https://github.com/qqqzhch/webfans 什么是雪碧图? CSS雪碧 即CSS Sprites,也有人叫它CSS精灵,是一种CSS图像合并技术,该方法 ...
- compass与css sprite(雪碧图)
什么是css sprite? css sprite,中文叫雪碧图,也有人喊CSS精灵,就是一种背景拼合的技术,然后通过background-position来显示雪碧图中需要显示的图像. MDN相关链 ...
- sass制作雪碧图
1.配置文件config.rb http_path = "../../../" css_dir = "Content/css" sass_dir = " ...
- compass框架的sprite雪碧图的用法简要
---恢复内容开始--- **简介** CSS SPRITE 即 CSS雪碧,即是将诸多图片合成一张图片,然后使用CSS 的background和background-position属性渲染. 这样 ...
随机推荐
- 跳转到appstore下载app的链接 记录一下
这是链接: https://itunes.apple.com/cn/app/da-dou-dou-lao-shi/id1395835036?mt=8 其中值得一提的是mt参数是啥意思 见下图:
- querystring模块详解
querystring模块用于处理query字符串,包含以下方法: parse.decode escape unescape encode.stringify parse.decode方法 parse ...
- 4.使用Jackson将Json数据转换成实体数据
Jar下载地址:http://jackson.codehaus.org/ 注意: 一.类中的属性名称一定要和Json数据的属性名称一致(大写和小写敏感),类之间的嵌套关系也应该和Json数据的嵌套关系 ...
- 01_Docker概念简介、组件介绍、使用场景和命名空间
一.简介 Docker是一个能够把开发的应用程序自动部署到容器的开源引擎.Docker在虚拟化的容器执行环境中增加了一个应用程序部署引擎.该引擎的目标就是提供一个轻量.快速的环境,能够运行开发者的程序 ...
- pipeline 发布war包
pipline 写法分为 脚本式和声明式,下面采用脚本式编程: node { stage('checkout') { echo '开始检出代码' checkout([$class: 'GitSCM', ...
- n进制转十进制
#include<cstdio> #include<iostream> using namespace std; ; int main(){ ,len=; char ch[ma ...
- C语言中数组定义方式
<1>前言 大家首先来思考一个问题,若是我们想要定义两个变量,求这两个数的平均数,该怎么求呢? 例如:int a = 10,b = 20 int average = (a + b) / 2 ...
- flex 自定义组件的编写
使用flex也很久了,也改过别人写的flex自定义组件,但是就是没有系统的研究下flex组件的编写步骤,和要注意的东西,在这里我参照一本书中的例子,好好的理解下,也为了巩固下自己对flex的理解! 1 ...
- python+soket实现UDP协议的客户/服务端中文聊天程序
没什么特别的东西,网上烂大街的C/S框架.(基于windows 7 + python 3.4) 为了实现中文聊天,我加入了一点修改: msg.encode('utf-8') # msg 为输入(且将要 ...
- 学习OpenCV——SVM
学习OpenCV——SVM 学习SVM,首先通过http://zh.wikipedia.org/wiki/SVM, 再通过博客http://blog.csdn.net/yang_xian521/art ...