Web课程学习笔记--CSS-Sprite的应用

雪碧图CSS Sprite的应用

CSS雪碧,即CSS Sprite,也有人叫它CSS精灵,是一种CSS图像合并技术,该方法是将小图标和背景图像合并到一张图片上,然后利用css的背景定位来显示需要显示的图片部分。例如常见的商品分类导航其实所有商品的背景图用的都是一个所有小图标拼凑成的大图,只是在不同类别显示对应类别的图标时,通过li背景定位到大图的对应图标的位置。背景图位置可以使用一些雪碧图生成工具的时候,生成对应的CSS样式文件里面会有对应的位置信息。

好处优点

有效减少网站的http请求数量,加速图片的显示。

条件

静态图片,图片不随用户信息的变化而变化。

小图片,容量比较小的(2-3KB)

图片加载量比较大的。

注意:大图片不建议用雪碧图咯,图片那么大,拼完之后岂不是拆机无敌大咯,加载就慢了,得不偿失!!!

原理

利用 css3的 background-position控制一个层可显示区域范围大小,通过一个窗口,对背景图进行滑动。
简单来说,就是利用这个属性,设置背景图需要显示的起始位置,在通过标签来控制背景图显示的范围。

background-position属性

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

根据图所知:

以左上角为(0,0)坐标

x,y都是负值

综上所诉,所以background-position的取值就是背景图显示的起始坐标,形式就是background-position:0, 0;

拼图

拼图可以用ps,或者网上很多在线雪碧图生成工具,可以利用这些去生成雪碧图。

其实最好的拼图就是每个图标边距是多少和图标周围的留白留多少都控制好,对css的background-position的坐标写起来有规律的话,好些很多(然而这个是我自己手动拖拉的,位置很没有规律,所以下面的坐标值都是调试过才取值的)

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

讲完这些了,可以来正题了,html和css代码了,下面代码是模仿生成一个菜单~~~

代码

<div id="content"><ul class="content"><li class="cat-1"><i></i><h3>女装/男装/内衣</h3></li><li class="cat-2"><i></i><h3>鞋靴/箱包/配件</h3></li><li class="cat-3"><i></i><h3>童装玩具/孕产/用品</h3></li><li class="cat-4"><i></i><h3>家电/数码/手机</h3></li><li class="cat-5"><i></i><h3>美妆/洗护/保健品</h3></li><li class="cat-6"><i></i><h3>珠宝/眼镜/手表</h3></li><li class="cat-7"><i></i><h3>运动/户外/乐器</h3></li><li class="cat-8"><i></i><h3>游戏/动漫/影视</h3></li><li class="cat-9"><i></i><h3>美食/生鲜/零食</h3></li><li class="cat-10"><i></i><h3>鲜花/宠物/农资</h3></li><li class="cat-11"><i></i><h3>房产/装修/建材</h3></li></ul>
</div>
#content{width: 180px;background: #f8f8f8;border: 1px solid #bbb;
}
h3{margin: 0;padding: 0;
}
ul{list-style: none;padding: 0;
}
li h3{font-size: 14px;font-weight: 400;
}
li{  margin:  3px 10px 0 0;display: block;height: 31px;line-height: 31px;overflow: hidden;border-bottom: 1px solid #dedede;}
li i{background:  url(sprite.png);display: inline;width: 40px;height: 28px;float: left;
}
.cat-1 i{background-position: -7px -5px;
}
.cat-2 i{background-position: -2px -35px;
}
.cat-3 i{background-position: -7px -65px;
}
.cat-4 i{background-position: -7px -105px;
}
.cat-5 i{background-position: -7px -129px;
}
.cat-6 i{background-position: -7px -151px;
}
.cat-7 i{background-position:-60px -4px;
}
.cat-8 i{background-position:-56px -33px;
}
.cat-9 i{background-position: -56px -66px;
}
.cat-10 i{background-position:-60px -103px;
}
.cat-11 i{background-position: -51px -128px;
}

效果图如下

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

}
.cat-10 i{
background-position:-60px -103px;
}
.cat-11 i{
background-position: -51px -128px;
}


## 效果图如下[外链图片转存中...(img-Fny7k0g5-1707132877339)]**本文转载自 忆桐之家的博客,<a href="http://hongyitong.github.io/2016/12/23/雪碧图CSS%20Sprite的应用/" rel="nofollow">《雪碧图CSS Sprite的应用》</a>**

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/455563.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

代码手术刀-自定义你的代码重构工具

前言 笔者近日在做代码仓库的存量代码缩减工作&#xff0c;首先考虑的是基于静态扫描的缩减&#xff0c;尝试使用了很多工具来对代码进行优化&#xff0c;例如PMD、IDEA自带的inspect功能、findBugs等。但是无一例外&#xff0c;要么过于“保守”&#xff0c;只给出扫描结果&a…

分享springboot框架的一个开源的本地开发部署教程(若依开源项目开发部署过程分享持续更新二开宝藏项目PostgresSQL数据库版)

1首先介绍下若依项目&#xff1a; 若依是一个基于Spring Boot和Spring Cloud技术栈开发的多租户权限管理系统。该开源项目提供了一套完整的权限管理解决方案&#xff0c;包括用户管理、角色管理、菜单管理、部门管理、岗位管理等功能。 若依项目采用前后端分离的架构&#xf…

基于OpenCV灰度图像转GCode的单向扫描实现

基于OpenCV灰度图像转GCode的单向扫描实现 引言单向扫描存在的问题灰度图像单向扫描代码示例结论 系列文章 ⭐深入理解G0和G1指令&#xff1a;C中的实现与激光雕刻应用⭐基于二值化图像转GCode的单向扫描实现⭐基于二值化图像转GCode的双向扫描实现⭐基于二值化图像转GCode的…

青马在线考试怎么搜题找答案?不妨看看这九个实用工具 #知识分享#微信#笔记

在信息爆炸的时代&#xff0c;选择适合自己的学习辅助工具和资料&#xff0c;能够提供更高效、便捷和多样化的学习方式。 1.WolframAlpha WolframAlpha堪称“数学解题神器”&#xff01; 可以搜索到大学多个专业的题目以及试卷答案&#xff0c;重点是提供的题目搜索大部分的…

第二代Qwen大模型发布,阿里巴巴一口气开源了30个不同参数规模的模型

关于Qwen-1.5系列更多信息参考DataLearnerAI原文&#xff1a; 重磅&#xff01;第二代通义千问大模型开源&#xff0c;阿里巴巴一口气开源了30个不同参数规模的模型&#xff0c;其中Qwen1.5-72B仅次于GPT-4.​www.datalearner.com/blog/1051707149237037​编辑https://link.zh…

性能实测:分布式存储 ZBS 与集中式存储 HDS 在 Oracle 数据库场景表现如何

作者&#xff1a;深耕行业的 SmartX 金融团队 金鑫 在金融客户的基础架构环境中&#xff0c;HDS 是一种被广泛使用的存储解决方案。作为集中式存储的代表之一&#xff0c;HDS 拥有高性能、高可用性和可扩展性的企业级存储特点&#xff0c;适用于实时数据处理、虚拟化和灾难备份…

Docker下安装GitLab

极狐GitLab Docker 镜像 | 极狐GitLab 安装所需最小配置 内存至少4G 系统内核至少3.10以上 uname -r 命令可以查看系统内核版本 安装Docker 1.更新 yum源 yum update 2.安装依赖(如果在操作第三步的时候提示yum-config-manager 未找到命令 就安装下面依赖) yum instal…

杨中科 ASP.NETCORE 高级14 SignalR

1、什么是websocket、SignalR 服务器向客户端发送数据 1、需求&#xff1a;Web聊天;站内沟通。 2、传统HTTP&#xff1a;只能客户端主动发送请求 3、传统方案&#xff1a;长轮询&#xff08;Long Polling&#xff09;。缺点是&#xff1f;&#xff08;1.客户端发送请求后&…

防范恶意勒索攻击!亚信安全发布《勒索家族和勒索事件监控报告》

本周态势快速感知 本周全球共监测到勒索事件81起&#xff0c;事件数量有所下降&#xff0c;比上月降低20%。 lockbit3.0仍然是影响最严重的勒索家族&#xff1b;akira和incransom也是两个活动频繁的恶意家族&#xff0c;需要注意防范。 本周alphv勒索组织窃取MBC法律专业公司…

[word] word表格内容自动编号 #经验分享#微信#其他

word表格内容自动编号 在表格中的内容怎么样自动编号&#xff1f;我们都知道Word表格和Excel表格有所不同&#xff0c;Excel表格可以轻松自动编号&#xff0c;那么在Word表格中如何自动编号呢&#xff1f; 1、选中内容后&#xff0c;点击段落-自动编号&#xff0c;选择其中一…

【网络安全】URL解析器混淆攻击实现ChatGPT账户接管、Glassdoor服务器XSS

文章目录 通配符URL解析器混淆攻击实现ChatGPT账户接管通配符URL解析器混淆攻击实现Glassdoor服务器缓存XSS 本文不承担任何由于传播、利用本文所发布内容而造成的任何后果及法律责任。 本文将基于ChatGPT及Glassdoor两个实例阐发URL解析器混淆攻击。 开始本文前&#xff0c;…

离线场景下任意文档的在线预览及原样格式翻译,不依赖其他厂商接口非侵入式一行js代码实现网站的翻译及国际化,可配置使用多种翻译语言

离线场景下任意文档的在线预览及原样格式翻译&#xff0c;不依赖其他厂商接口非侵入式一行js代码实现网站的翻译及国际化&#xff0c;可配置使用多种翻译语言。 要实现翻译需要解决以下3个主要问题&#xff1a; 1&#xff09;from&#xff1a;内容本身的语言类型是什么&#xf…