iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >怎样入门CSSSprites雪碧图技术
  • 622
分享到

怎样入门CSSSprites雪碧图技术

2024-04-02 19:04:59 622人浏览 八月长安
摘要

怎样入门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.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雪碧图技术问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网JavaScript频道了解更多相关知识。

--结束END--

本文标题: 怎样入门CSSSprites雪碧图技术

本文链接: https://www.lsjlt.com/news/81425.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 怎样入门CSSSprites雪碧图技术
    怎样入门CSSSprites雪碧图技术,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。雪碧图被运用在众多使用了很多小图标的网站上。相对于把每...
    99+
    2024-04-02
  • pycharm怎样调试debug入门_pycharm调试debug入门技巧
    1.打开界面后,导入一个项目文件 2.打开Python文件,在要debug的地方添加一个断点 3.点击顶部的Run菜单,选择debug选项 4.下面我们可以看到当程序运行到debu...
    99+
    2024-05-10
    python pycharm
  • 怎么样学习云计算相关技术?云应用如何入门学习?
    零基础学习云计算,云计算学习如何入门?近年来Linux云计算已经越来越受到重用,它不再仅仅是一些开源发烧友们之间炫耀资本,而且已经在多方面价值得到了体现,尤其在服务器操作系统方面,已经成为资深运维工程师的首选的操作工具。忘掉Windows的...
    99+
    2023-06-04
  • Java的poi技术怎样读取和导入Excel
    这期内容当中小编将会给大家带来有关Java的poi技术怎样读取和导入Excel,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。项目结构:用到的Excel文件:XlsMain .java 类//该类有main...
    99+
    2023-06-17
  • python入门turtle库怎样实现螺旋曲线图
    本篇文章为大家展示了python入门turtle库怎样实现螺旋曲线图,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。记录turtle库中经常用到的函数。turtle.forward(distance)...
    99+
    2023-06-21
  • 0基础Python入门学习路线图应该是怎样的?
    Python因语法简洁功能强大,受到了很多初学者的喜爱,很多人奔着就业的目的自学Python,那么在自学之前,小优会首先建议同学先充分了解Python的岗位性质,工作内容,然后通过网课自学先试学一下,如果自己真的感兴趣,就可以规划自己的学习...
    99+
    2023-06-02
  • Python爬虫入门中8个常用爬虫技巧盘点分别是怎样的
    今天就跟大家聊聊有关Python爬虫入门中8个常用爬虫技巧盘点分别是怎样的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。编程对于任何一个新手来说都不是一件容易的事情,Python对于...
    99+
    2023-06-02
  • 图数据库查询语言Gremlin vs Cypher vs nGQL的操作入门是怎样的
    图数据库查询语言Gremlin vs Cypher vs nGQL的操作入门是怎样的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。文章的开...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作