css之雪碧图(精灵图)

听到雪碧图是不是跟我一样,啥?雪碧图?不知所以。

如果一张大图由许多小图构成,那么每张小图都需要进行网络请求,这样一来就会有很多请求,为了减少网络请求,雪碧图就出现了。

雪碧图(Sprite)是一种在Web开发中常用的图像合并技术,将多个小图标或图片合并成一张大图,然后通过CSS来显示其不同部分。这种技术可以减少HTTP请求数量,提高网页加载速度。

以下是本人自己写的例子,大图的图片是在百度找的https://img2.baidu.com/it/u=2480900908,627122939&fm=253&fmt=auto&app=138&f=JPEG?w=602&h=231

原图长这样

代码运行长这样:

代码如下:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div{
            display: flex;
        }
        .icon1{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -5px 1px;
            /* border: 1px solid #000; */
        }

        .icon2{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -95px 1px;
        }
        .icon3{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -185px 1px;
        }
        .icon4{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -275px 1px;
        }
        .icon5{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -365px 1px;
        }
        .icon6{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -455px 1px;
        }
        .icon7{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -545px 1px;
        }
        .icon2-1{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -5px -90px;
        }
        .icon2-2{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -95px -90px;
        }
        .icon2-3{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -185px -90px;
        }
        .icon2-4{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -275px -90px;
        }
        .icon2-5{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -365px -90px;
        }
        .icon2-6{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -455px -90px;
        }
        .icon2-7{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -545px -90px;
        }
        .icon3-1{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -5px -179px;
        }
        .icon3-2{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -95px -179px;
        }
        .icon3-3{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -185px -179px;
        }
        .icon3-4{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -275px -179px;
        }
        .icon3-5{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -365px -179px;
        }
        .icon3-6{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -455px -179px;
        }
        .icon3-7{
            display: block;
            background-image: url("@/../xuebitu.jpg");
            width:50px;
            height:55px;
            background-position: -545px -179px;
        }
    </style>
</head>
<body> 
    <div>
        <span class="icon1"></span>
        <span class="icon2"></span>
        <span class="icon3"></span>
        <span class="icon4"></span>
        <span class="icon5"></span>
        <span class="icon6"></span>
        <span class="icon7"></span>
    </div>
    <div>
        <span class="icon2-1"></span>
        <span class="icon2-2"></span>
        <span class="icon2-3"></span>
        <span class="icon2-4"></span>
        <span class="icon2-5"></span>
        <span class="icon2-6"></span>
        <span class="icon2-7"></span>
    </div>
    <div>
        <span class="icon3-1"></span>
        <span class="icon3-2"></span>
        <span class="icon3-3"></span>
        <span class="icon3-4"></span>
        <span class="icon3-5"></span>
        <span class="icon3-6"></span>
        <span class="icon3-7"></span>
    </div>
    <!-- <span class="icon2"></span> -->
</body>
</html>
相关推荐
恋猫de小郭5 分钟前
Android Studio Cloud 正式上线,不只是 Android,随时随地改 bug
android·前端·flutter
清岚_lxn5 小时前
原生SSE实现AI智能问答+Vue3前端打字机流效果
前端·javascript·人工智能·vue·ai问答
ZoeLandia5 小时前
Element UI 设置 el-table-column 宽度 width 为百分比无效
前端·ui·element-ui
橘子味的冰淇淋~6 小时前
解决 vite.config.ts 引入scss 预处理报错
前端·vue·scss
小小小小宇7 小时前
V8 引擎垃圾回收机制详解
前端
lauo8 小时前
智体知识库:ai-docs对分布式智体编程语言Poplang和javascript的语法的比较(知识库问答)
开发语言·前端·javascript·分布式·机器人·开源
拉不动的猪8 小时前
设计模式之------单例模式
前端·javascript·面试
一袋米扛几楼988 小时前
【React框架】什么是 Vite?如何使用vite自动生成react的目录?
前端·react.js·前端框架
Alt.98 小时前
SpringMVC基础二(RestFul、接收数据、视图跳转)
java·开发语言·前端·mvc
进取星辰9 小时前
1、从零搭建魔法工坊:React 19 新手村生存指南
前端·react.js·前端框架