我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎样入门CSSSprites雪碧图技术

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

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎样入门CSSSprites雪碧图技术

怎样入门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.class="lazy" data-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

怎样入门CSSSprites雪碧图技术

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么样学习云计算相关技术?云应用如何入门学习?

零基础学习云计算,云计算学习如何入门?近年来Linux云计算已经越来越受到重用,它不再仅仅是一些开源发烧友们之间炫耀资本,而且已经在多方面价值得到了体现,尤其在服务器操作系统方面,已经成为资深运维工程师的首选的操作工具。1.忘掉Window
2023-06-04

编程热搜

目录