文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎样入门CSSSprites雪碧图技术

2024-04-02 19:55

关注

怎样入门CSSSprites雪碧图技术,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

雪碧图被运用在众多使用了很多小图标的网站上。相对于把每张小图标以.png格式文件的形式引用到页面上,使用雪碧图只需要引用一张图片,对内存和带宽更加友好。

实现
假设我们通过.toolbtn的类,为应用该类的各元素提供一张背景图片:

CSS Code复制内容到剪贴板

<style> .toolbtn {background:url(myfile.png); display:inline-block; height:20px; width:20px} </style>

背景位置,可以通过在background的url()直接定义X,Y轴的值,或者通过background-position属性来添加。例如:

CSS Code复制内容到剪贴板

<style>   
#btn1 {background-position: -20px 0px}   
#btn2 {background-position: -40px 0px}   
</style>

id=btn1的元素背景左移20px,id=btn2的元素背景左移40px(假设这两个元素的都添加了toolbtn类,应用了上面样式定义的图片效果)

类似的,你也可以使用下面的方式添加hover的状态:

CSS Code复制内容到剪贴板

  1. #btn:hover {background-position: [pixels shifted rightright]px [pixels shifted down]px;}  

CSS雪碧的基本原理是把你的网站上用到的一些图片整合到一张单独的图片中,从而减少你的网站的HTTP请求数量。该图片使用CSS background和background-position属性渲染(值得一提的是,这也就意味着你的标签变得更加复杂了,图片是在CSS中定义,而非<img>标签)。

使用css-sprite雪碧图工具
可能是最好用的雪碧图工具了,好吧,至少是我用过最好用的。

首先安装css-sprite,安装这里很坑,等我最后再说。

代码如下:

npm install css-sprite


我是使用gulp来构建前端代码,所以还需要安装gulp和gulp-if,安装好之后就可以开始配置啦。
新建一个task:

全选复制放进笔记var gulp = require('gulp');

JavaScript Code复制内容到剪贴板

  1. var gulpif = require('gulp-if');   
      
    gulp.task('sprites',function(){   
        gulp.src('img/icon/*.png')                  //这是要合并的图片的路径   
            .pipe(sprite({   
                name: 'icon',                       //定义一个名称   
                style: '_icon.scss',                //这是生成的样式文件   
                format: 'png',                      //png格式的图片   
                orientation: 'left-right',          //雪碧图合并的方向,也可以设置成垂直或水平   
                cssPath: '#{$icon-sprite-path}',    //雪碧图的路径变量   
                template: './sprite-tpl.mustache',  //scss生成的模板   
                processor: 'scss'                   //生成的样式文件的格式   
            }))   
            .pipe(gulpif('*.png', gulp.dest('img/'), gulp.dest('css/')));   
    });

scss的模板使用mustache:

CSS Code复制内容到剪贴板

  1. {{#items}}   
        ${{name}}: {{px.offset_x}} {{px.offset_y}} {{px.width}} {{px.height}};   
    {{/items}}   
      
    @mixin sprite-width($sprite) {   
    width: nth($sprite, 3);   
    }   
      
    @mixin sprite-height($sprite) {   
    height: nth($sprite, 4);   
    }   
      
    @mixin sprite-position($sprite) {   
    $sprite-offset-x: nth($sprite, 1);   
    $sprite-offset-y: nth($sprite, 2);   
    background-position: $sprite-offset-x  $sprite-offset-y;   
    }   
      
    @mixin sprite($sprite) {   
    @include sprite-position($sprite);   
      
    @include sprite-width($sprite);   
    @include sprite-height($sprite);   
      
    }   
      
    {{#sprite}}   
        {{class}} {   
        background-repeat: no-repeat;   
        overflow: hidden;   
        border: none;   
        background: url('{{{escaped_image}}}?v=#{$version}');   
        @include inline-block();   
        vertical-align: middle;   
        font-style: normal;   
        color:$icon-font-color;   
        }   
    {{/sprite}}   
      
    {{#items}}   
        .{{name}}{   
        @include sprite(${{name}});   
        }   
    {{/items}}  
    搞定!就是那么简单。
    现在只需要把图片丢到icon文件夹里面,运行下gulp sprites,就可以生成一张雪碧图icon.png和相对应的scss样式文件_icon.scss了,也可以再新建一个监听的任务,监听icon文件夹,这样就可以实时生成了。
    我把_icon.scss贴出来:
    CSS Code复制内容到剪贴板
    $icon-qq: -262px -161px 60px 60px;   
    $icon-email: -332px -161px 60px 60px;   
    $icon-skype: -5px -252px 60px 60px;   
    $icon-phone: -75px -252px 60px 60px;   
    @mixin sprite-width($sprite) {   
    width: nth($sprite, 3);   
    }   
      
    @mixin sprite-height($sprite) {   
    height: nth($sprite, 4);   
    }   
      
    @mixin sprite-position($sprite) {   
    $sprite-offset-x: nth($sprite, 1);   
    $sprite-offset-y: nth($sprite, 2);   
    background-position: $sprite-offset-x  $sprite-offset-y;   
    }   
      
    @mixin sprite($sprite) {   
    @include sprite-position($sprite);   
      
    @include sprite-width($sprite);   
    @include sprite-height($sprite);   
      
    }   
    .icon {   
        background-repeat: no-repeat;   
        overflow: hidden;   
        border: none;   
        background: url('#{$icon-sprite-path}/icon.png?v=#{$version}');   
        @include inline-block();   
        vertical-align: middle;   
        font-style: normal;   
        color:$icon-font-color;   
    }   
    .icon-qq{   
        @include sprite($icon-qq);   
    }   
    .icon-email{   
        @include sprite($icon-email);   
    }   
    .icon-skype{   
        @include sprite($icon-skype);   
    }   
    .icon-phone{   
        @include sprite($icon-phone);   
    }

使用的时候只需要加上类似class="icon icon-qq",就可以了。

关于怎样入门CSSSprites雪碧图技术问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网行业资讯频道了解更多相关知识。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯