前端优化:css雪碧图实践应用详解
前端是接近用户体验的一个项目组成部分,合适的优化能够大大减少网页响应时间,合理的资源加载自然成为了工作中的要务,现在就结合实例讲解到底什么是css雪碧图,以及工作中的实际应用。
一 、为什么需要使用雪碧图
比方说现在经理要我们给页面添加一个侧边任务栏,效果如下:
呵呵,作为一名资(too)深(young)的前端,我刷刷刷为页面增加ul还有几个然后再给每个li添加背景图片,哈哈,任务就这么完成了,然后commit了一下自己的代码。此处应该要有代码
html部分
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>雪碧图实例</title>
<link rel="stylesheet" type="text/css" href="css/index.css">
</head>
<body>
<ul class="function">
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
</body>
</html>
- css部分
* {
box-sizing: border-box;
padding: 0;
margin: 0;
}
body {
font-size: 18px;
}
.function {
list-style: none;
display: inline-block;
}
.function li {
width: 40px;
height: 40px;
margin-bottom: 5px;
background: #E0E0E0;
background-repeat: no-repeat;
}
.function li:nth-child(1) {
background-image: url(../img/all.png);
}
.function li:nth-child(2) {
background-image: url(../img/back.png);
}
.function li:nth-child(3) {
background-image: url(../img/cart.png);
}
.function li:nth-child(4) {
background-image: url(../img/Category.png);
}
.function li:nth-child(5) {
background-image: url(../img/close.png);
}
但是等到项目上线的时候,经理说小徐啊,这网页响应有点慢啊!怎么可能!于是我打开chrome按下F12查看network
我们可以看到这里有几张不到1k的小图片就这点大小还占用了5个请求,网页响应变慢了也不难理解。于是这时候css雪碧图就出现!
二、CSS雪碧图原理及应用
原理:把小图标合成一张大图,通过给元素的公共css设置background-image为该合成图,这样每个元素都会以该合成图为背景,而且页面也只加载一张合成图,然后再给每个元素单独微调其background-position。把多个请求合并成一个。
步骤:
合并图片
首先我们要对图片进行合并,方式有很多种,可以通过gulp,webpack等构建工具或者一些在线工具,这里提供一个很好用的在线的图片合并网站
http://csssprites.com/可以根据自己的需要添加边距等等,还会生成对应的参考css设置css(此处必须有代码)
* {
box-sizing: border-box;
padding: 0;
margin: 0;
}
body {
font-size: 18px;
}
.function {
list-style: none;
display: inline-block;
}
.function li {
width: 33px;
height: 33px;
margin-bottom: 5px;
background: #E0E0E0;
background-image: url(../img/result.png); /*result.png为合并后的图片*/
background-repeat: no-repeat;
}
.function li:nth-child(1) {
background-position: 0 0;
}
.function li:nth-child(2) {
background-position: 0 -35px;
}
.function li:nth-child(3) {
background-position: 0 -72px;
}
.function li:nth-child(4) {
background-position: 0 -110px;
}
.function li:nth-child(5) {
background-position: 0 -145px;
}
- 效果: 这时候我们再打开chrome的network查看请求数
有没有发现呢?原本的5个图片请求变成了1个。这时候我们可以再次自信的跟经理说,问题解决啦!
前端优化:css雪碧图实践应用详解的更多相关文章
- css雪碧图(精灵图)与字体图标的介绍以及对比
css雪碧图(精灵图)与字体图标的介绍以及对比 设想一个实际场景:在一个页面为了展示,我们放置了很多独立的小图片,浏览器在显示页面的时候,就需要向服务器就会发送很多请求,来获取并加载这些小图片,但是这 ...
- 使用compass自动合并css雪碧图(css sprite)
本文转载自: 使用compass自动合并css雪碧图(css sprite)
- Css雪碧图
Css雪碧图: CSS雪碧 即CSS Sprite,也有人叫它CSS精灵,是一种CSS图像合并技术,该方法是将小图标和背景图像合并到一张图片上,然后利用css的背景定位来显示需要显示的图片部分. 原理 ...
- CSS Sprite、CSS雪碧图应用实例
CSS Sprites技术被国内一些人称为CSS雪碧图,其实就是把网页中一些背景图片整合到一张图片文件中,再利用CSS的“background-image”,“background- repeat”, ...
- CSS雪碧图(精灵图)使用
1:CSS雪碧图:CSS雪碧图 即 CSS Sprites,也有人叫它CSS精灵图. 2:雪碧图的由来:一个网站的页面需要大量的小图片或者小图标,但是大量的图片如果放在服务器上,每次当打开网站并且向服 ...
- css雪碧图实现数字切换
vue中 css 雪碧图应用及数字切换demo 1. CSS Sprites一般只能使用到固定大小的盒子(box)里,这样才能够遮挡住不应该看到的部分. 2.使用css雪碧图的优点: 利用CSS Sp ...
- css雪碧图压缩
cssgaga下载地址 链接: https://pan.baidu.com/s/1Q9xH_XzumIc7vTLCZ3tr5A 提取码: stqe CssGaga功能特性 合并import的CSS文件 ...
- css sprite,css雪碧图生成工具V3.0更新
V3.0主要改进 1.增加了单独添加单张图片以及删除单张图片的功能 2.增加了生成.sprite文件用以保存雪碧图信息 3.增加了打开.sprite文件功能 什么是css sprite CSS spr ...
- css 雪碧图的制作
很多网站其实都用了雪碧图,确实方便了制作,以前以为这种小图标,都是一个一个图片呢(笑) 效果图如下: 代码如下: <html> <head lang="en"&g ...
随机推荐
- klee源码阅读笔记1--STPBuilder类
初始化过程中四个数据成员中的两个数据成员被初始化: 一.vc被初始化为STP提供的C调用接口函数vc_createValidityChecker(): 二.optimizeDivides被初始化为fa ...
- 关于pom版本提交不成功的问题
今天碰到个问题:我在原来的一个pom项目的client服务里面修改了一个java类,但是没有升级版本.然后再预发环境更新后,从显示的日志来看,仍然是我修改前的版本. 这就奇怪了,看了svn确实已经提交 ...
- 利用NVM在系统中维护多个版本的nodejs
0. 背景 开发时可能同时进行多个项目,而这些项目所依赖的node版本又不是一样的.比如我现在的angular项目采用的node是8.9.3版本,而vue项目的vue-cli则依赖更高.由于ang ...
- 我要为运维说一句,我们不是网管,好不!!Are you know?
运维 运维,这里指互联网运维,通常属于技术部门,与研发.测试.系统管理同为互联网产品技术支撑的4大部门,这个划分在国内和国外以及大小公司间都会多少有一些不同. 一个互联网产品的生成一般经历的过程是:产 ...
- leetcode-longest palindromic substring-by 1337c0d3r
Given a string S, find the longest palindromic substring in S. Note:This is Part II of the article: ...
- [问题记录]cocos的lua绑定安装pyyaml报错
描述:按照readme中的文档操作报错,提示python2.7没有安装,但是确实已经安装了,而且也设置环境变量成功了. 解决: 在D盘新建register.py的文件,内容如下: # # script ...
- .net 面向对象程序设计深入](3)UML
1.活动图简介 定义:是阐明了业务用例实现的工作流程. 业务工作流程说明了业务为向所服务的业务主角提供其所需的价值而必须完成的工作. 业务用例由一系列活动组成,它们共同为业务主角生成某些工件. 工作流 ...
- lua之m进制转换为n进制-任意进制转换算法
够无聊的写这个,为防止需要的人也无聊一遍,写个吧 算法有n种,但是,咱们一种就够用了 --数组倒序排列 local function orderByDesc( input ) local output ...
- 026json和pickle,xml模块
###json和pickle ##json#dumps()data = #源数据data = json.dumps(data)这时候的data可以写入到文件了#loads()data = f.read ...
- linux 安装pip 和python3
前言: python3应该是python的趋势所在,当然目前争议也比较大,这篇随笔的主要目的是记录在linux6.4下搭建python3环境的过程 以及碰到的问题和解决过程. 另外,如果本机安装了py ...