文档章节

CSS Sprite——CSS雪碧图

上古遗露
 上古遗露
发布于 2015/12/16 00:53
字数 858
阅读 42
收藏 0

雪碧图的使用原则

  1. 静态图片,不随用户信息变化而变化

  2. 小图片,图片容量较小

  3. 加载量较大的情况下使用

  4. 大图不建议使用雪碧图

作用

  1. 减少HTTP的请求数量:每请求一次,就会和服务器链接一次,建立连接需要额外的时间

  2. 加速内容的显示

实现原理

通过CSS background-position实现

控制一个层可显示区域范围的大小,通过一个窗口,进行背景图的滑动

实现方式

  1. PS手动拼图,要记住每张图的坐标点

  2. 使用sprite自动生成工具(CssGaga:www.99css.com/archives/1524)

实例

HTML代码:

<html>
<head>
<!--准备一个空白的HTML页面,同时完成css reset样式 -->
<meta charset="utf-8">
<style>
    * {padding:0; margin:0;}
    ul{ list-style-type:none; border:1px solid #555;}
    li {  border-bottom:1px solid #eee;display:block; overflow:hidden; height:32px; line-height:32px;}
    li h3 {font-size:15px; font-weight:400; font-family:“微软雅黑”;}
    .cat { width:150px; background:#f8f8f8;}
</style>
<!--补充完整的样式-->
</head>
<body>
<div class="cat">
    <ul>
        <li>
            <i class="cat_1"></i>
            <h3>服装内衣</h3>
        </li>
        <li>
            <i class="cat_2"></i>
            <h3>鞋包配饰</h3>
        </li>
        <li>
            <i class="cat_3"></i>
            <h3>运动户外</h3>
        </li>
        <li>
            <i class="cat_4"></i>
            <h3>珠宝手表</h3>
        </li>
        <li>
            <i class="cat_5"></i>
            <h3>手机数码</h3>
        </li>
        <li>
            <i class="cat_6"></i>
            <h3>家电办公</h3>
        </li>
        <li>
            <i class="cat_7"></i>
            <h3>护肤彩妆</h3>
        </li>
            <li>
            <i class="cat_8"></i>
            <h3>母婴用品</h3>
        </li>
    </ul>
</div>
</body>
</html>

雪碧图:

实现雪碧图:

li i { 
        background:url(http://img.mukewang.com/539a950e00015ba500710200.jpg); 
        display:inline; 
        float:left; 
        width:30px; 
        height:24px;
        margin:3px 10px 0 0;
    }
    .cat_1 { background-position:0 0; }
    .cat_2 { background-position:0 -24px; }
    .cat_3 { background-position:0 -48px; }
    .cat_4 { background-position:0 -72px; }
    .cat_5 { background-position:0 -96px; }
    .cat_6 { background-position:0 -120px; }
    .cat_7 { background-position:0 -144px; }
    .cat_8 { background-position:-40px -168px; }

效果:

登陆的雪碧图应用

雪碧图:

HTML:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>无标题文档</title>

</head>

<body>
<div class="login">
    <form method="post" action="" name="loginForm">
        <input type="text" name="username" placeholder="邮箱/手机号/用户名">
        <input type="password" name="password" placeholder="请输入密码">
        <input type="checkbox" name="auto_login" id="auto_login"><label for="auto_login">下次自动登陆</label>
        <a href="javascript:;">忘记密码?</a>
        <input type="submit" name="login_submit" value="登录">
        <input type="submit" name="register_submit" value="注册">
    </form>
</div>
</body>
</html>

效果:

设置CSS样式:

<style type="text/css">
	blockquote, body, button, dd, dl, dt, fieldset, form, h1, h2, h3, h4, h5, h6, hr, input, legend, li, ol, p, pre, td, textarea, th, ul{
        margin: 0;
        padding: 0;
    }
    .login {
        background-color:#ebf3fa;
        width:200px;
        overflow:hidden;
        padding:25px;
    }
    .login * {
        border-radius:3px;
        margin:5px 0;
    }
    .login input[type="text"],
    .login input[type="password"] {
        width:190px;
        height:35px;
        text-indent:20px;
        clear:both;
    }
    .login label[for="auto_login"] {
        font-size:10px;
    }
    .login a {
        text-decoration:none;
        font-size:10px;
    }
    .login input[type="submit"],
    .login input[type="login"] {
        width:190px;
        height:35px;
        color:#fff;
        word-spacing:5px;
        text-align:center;
        line-height:35px;
    }
    .login input[name*="submit"] {
        background:url(login.png) 0 0;
    }
    .login input[name*="register"] {
		background:url(login.png) 0 -38px;    
    }
    
</style>

效果:

CSS display:inline和float:left两者区别

①display:inline:任何不是块级元素的可见元素都是内联元素。其表现的特性是&ldquo;行布局&rdquo;形式!(行布局:其表现形式始终以行进行显示) ②float:left:指定元素脱离普通的文档流而产生的特别的布局特性。并且float必需应用在块级元素之上,也就是说浮动并不应用于内联标签。或者可以说如果应用了float这个元素将被指定为块级元素。 那么两者的区别显而易见:display:inline元素不能设置宽高,因为它属于行布局,其特性是在一行里进行布局,所以不能被设定宽高

© 著作权归作者所有

共有 人打赏支持
上古遗露
粉丝 7
博文 56
码字总数 42929
作品 0
苏州
compass精灵图

css雪碧图又叫css精灵或css sprite,是一种背景图片的拼合技术。使用css雪碧图,能够减少页面的请求数、降低图片占用的字节,以此来达到提升页面访问速度的目的。但是它也有令人诟病的地方,...

Billydotzhang
2016/11/17
9
0
切片合并雪碧图--grunt-css-sprite

grunt-css-sprite 这是什么 这是一个帮助前端开发工程师将 css 代码中的切片合并成雪碧图的工具; 其灵感来源于 grunt-sprite,由于其配置参数限制目录结构等,不能满足通用项目需求,重新造...

米空格
2015/01/29
1K
0
QMUI Web 框架正式发布 2.0 版本

QMUI Web 是一个专注 Web UI 开发,帮助开发者快速实现特定的一整套设计的框架。框架主要由一个强大的 SASS 方法合集与内置的工作流构成,由QMUI 团队出品。 重要更新 本次框架更新版为 2.0 ...

kayo5994
2017/04/11
2.9K
2
移动端使用 rem 单位时 css sprites 定位问题

现在开发移动端 wap 页面,相信大家都会使用强大的 rem 单位去适配各种机型和屏幕;为了减少网络请求数量,提高网页访问性能,一般都会把多个小 icon 合并成一张 sprite 图,然后根据 backgr...

幽涯
06/17
0
0
今天是仿淘宝的第一天,CSS sprite

今天是仿淘宝首页的第一天,对于刚入前端门的我来说,仿写淘宝首页不是那么的容易,所以第一天我大致把淘宝首页先分类割化成小块,一点一点攻破~吼吼~然后在网上查了些资料,结合自己的想法,...

Kvera
2016/08/18
41
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

OSChina 周三乱弹 —— 我居然在 osc 里追剧

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @舆情风控小组 :分享王菲的单曲《笑忘书》 《笑忘书》- 王菲 手机党少年们想听歌,请使劲儿戳(这里) @艾尔库鲁斯:如果给大家一个选择的机...

小小编辑
39分钟前
57
6
rabbitMq的客户端使用笔记

1、channel声明队列的queueDeclare方法的参数解析 durable: 是否持久化, 队列的声明默认是存放到内存中的,如果rabbitmq重启会丢失,如果想重启之后还存在就要使队列持久化,保存到Erlang自...

DemonsI
47分钟前
0
0
“全新” 编程语言 Julia开箱体验

本文共 851字,阅读大约需要 3分钟 ! 概 述 Julia 是一个 “全新”的高性能动态编程语言,前两天迎来了其 1.0 正式版的重大更新。Julia集 Python、C、R、Ruby 之所长,感觉就像一种脚本语言...

CodeSheep
今天
12
0
软件自动化测试初学者忠告

题外话 测试入门 很多受过高等教育的大学生经常问要不要去报测试培训班来入门测试。 答案是否。 高等教育的合格毕业生要具备自学能力,如果你不具备自学能力,要好好地反省一下,为什么自己受...

python测试开发人工智能安全
今天
5
0
java并发备忘

不安全的“先检查后执行”,代码形式如下: if(条件满足){ //这里容易出现线程安全问题//doSomething}else{//doOther} 读取-修改-写入 原子操作:使用CAS技术,即首先从V中读取...

Funcy1122
今天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部