zoukankan      html  css  js  c++  java
  • compass模块----Utilities----Sprites精灵图合图

    css雪碧图又叫css精灵或css sprite,是一种背景图片的拼合技术。使用css雪碧图,能够减少页面的请求数、降低图片占用的字节,以此来达到提升页面访问速度的目的。但是它也有令人诟病的地方,就是拼图和后期维护的成本比较大。也正是因为这一点,导致很多开发者懒于使用css雪碧图。

    配置compass项目

    $ compass init

    会生成相应的目录和配置文件。在images目录下建立logo目录存放需合并的图标。项目目录结构如下:

    - sass
    |-- icons.scss
    |-- screen.scss - stylesheet - images |-- logo

     config.rb 文件配置如下:

    1 http_path = "/"
    2 css_dir = "stylesheets"
    3 sass_dir = "sass"
    4 images_dir = "images"
    5 javascripts_dir = "javascripts"
    6 
    7 relative_assets = true    // 使用相对目录
    8 line_comments = false    // 关闭行注释

    合并雪碧图

    输出所有雪碧图样式

    新建一个文件icons.scss,在screen.scss中引入icons.scss。

    在icons.scss里面引入sprites@import "compass/utilities/sprites" 

    images文件里子目录logo:把所有图片放到这里。(方便将来将其和其他图片区分开来)

    icons.scss文件里将logo文件引入进来: @import "logo/*.png"; (*引入logo目录下的所有文件)。

    1 @import "compass/utilities/sprites";    // 加载compass sprites模块
    2 @import "share/*.png";                    // 导入share目录下所有png图片
    3 @include all-share-sprites;                // 输出所有的雪碧图css

    生成的代码中 .logo-sprite 是雪碧图的基础类生成的每个雪碧图默认的class规则是: .目录名-图片名 。

    调用单个雪碧图样式

    1 @import "compass/utilities/sprites";    // 加载compass sprites模块
    2 @import "share/*.png";                    // 导入logo目录下所有png图片
    3 .main-logo{
    4     @include logo-sprite("img1");
    5 }

    编译后的css为:

    1 .logo-sprite, .main-logo {
    2     background-image: url('../images/logo-sd097a30ac3.png');
    3     background-repeat: no-repeat;
    4 }
    5 .main-logo {
    6     background-position: 0 0;
    7 }

    利用魔术精灵选择器智能输出

    比如hoveractivefocustarget等。利用compass的魔术精灵选择器我们就可以智能的合并各状态的图标,并输出对应的css。使用时,我们需要将图标按照一定的规则命名。例如:

    img1.png            // 默认状态图标
    img1_hover.png     // hover状态图标
    img1_active.png     // active状态图标

    编译后的css为:

     1 .logo-sprite, .main-logo {
     2   background-image: url('../images/logo-sd097a30ac3.png');
     3   background-repeat: no-repeat;
     4 }
     5 .main-logo {
     6   background-position: 0 0;
     7 }
     8 .main-logo:hover, .main-logo.img1-hover {
     9   background-position: -120px 0;
    10 }
    11 .main-logo:active, .main-logo.img1-active {
    12   background-position: -60px 0;
    13 }

     


    调出隐藏的logo.scss命令行:

    compass sprite 'images/logo/*.png'

    $logo-sprite-dimensions:用来控制输出CSS的时候是否根据图片大小对我们的相应类名css属性添加一个宽和高。
    $logo-layout:修改合图布局方式。

      --默认是垂直 horizontal水平的。

      --diagonal斜对角线布局的。

      --smart节省空间布局

    1 $logo-sprite-dimensions: true;
    2 $logo-layout: horizontal;
     
  • 相关阅读:
    ng-深度学习-课程笔记-1: 介绍深度学习(Week1)
    java发送http请求和多线程
    Spring Cloud Eureka注册中心(快速搭建)
    Spring boot集成Swagger2,并配置多个扫描路径,添加swagger-ui-layer
    springboot在idea的RunDashboard如何显示出来
    Oracle 中select XX_id_seq.nextval from dual 什么意思呢?
    mysql类似to_char()to_date()函数mysql日期和字符相互转换方法date_f
    MySQL的Limit详解
    HikariCP 个人实例
    NBA-2018骑士季后赛
  • 原文地址:https://www.cnblogs.com/alice-shan/p/5012610.html
Copyright © 2011-2022 走看看