目次
6.1 エルフの仕組み
6.2 エルフの重要性
// 1. Compass に elf フォルダーを指定します
6.3.1 スプライトマップを作成する
1 @import "compass/utilities/sprites";    // 精灵图片控件;2 @import "Icon/*.png";                   // Icon文件夹位于images文件夹内并包含所有精灵图片;3 4 // 生成精灵图片位于images文件夹内;并生成编译后的CSS;5 CSS: 6     .Icon-sprite {             // 自动生成的类命名; 7       background-image: url('/images/Icon-s040daee5af.png'); 8       background-repeat: no-repeat; 9     }
ログイン後にコピー
" >
1 @import "compass/utilities/sprites";    // 精灵图片控件;2 @import "Icon/*.png";                   // Icon文件夹位于images文件夹内并包含所有精灵图片;3 4 // 生成精灵图片位于images文件夹内;并生成编译后的CSS;5 CSS: 6     .Icon-sprite {             // 自动生成的类命名; 7       background-image: url('/images/Icon-s040daee5af.png'); 8       background-repeat: no-repeat; 9     }
ログイン後にコピー
6.3.2 スプライトを導入して CSS を生成する
 1 1.all-sprites精灵混合器  2 Sass:  3     @include all-Icon-sprites; // 为整个精灵地图撰写所有必要的CSS; 4 CSS:                     // 生成内容;  5     .Icon-sprite, .Icon-index1, .Icon-index2, .Icon-index3, .Icon-index4, .Icon-index5 {  6         background-image: url('/images/Icon-s040daee5af.png');  // 所有的相关类都引用此图片;  7         background-repeat: no-repeat;  8  }  9     .Icon-index1 { 10         background-position: 0 0; 11  } 12  ... 13     .Icon-index5 { 14         background-position: 0 -560px; 15  } 16 17 // 使用@extend继承精灵的样式18 Sass: 19     .add-button { @extend .Icon-index1} // 这种方法会生成更少的CSS;20 CSS: 21     .Icon-index1, .add-button {     // 直接叠加了一个类,比较方便; 22         background-position: 0 0; 23     }
ログイン後にコピー
" >
 1 1.all-sprites精灵混合器  2 Sass:  3     @include all-Icon-sprites; // 为整个精灵地图撰写所有必要的CSS; 4 CSS:                     // 生成内容;  5     .Icon-sprite, .Icon-index1, .Icon-index2, .Icon-index3, .Icon-index4, .Icon-index5 {  6         background-image: url('/images/Icon-s040daee5af.png');  // 所有的相关类都引用此图片;  7         background-repeat: no-repeat;  8  }  9     .Icon-index1 { 10         background-position: 0 0; 11  } 12  ... 13     .Icon-index5 { 14         background-position: 0 -560px; 15  } 16 17 // 使用@extend继承精灵的样式18 Sass: 19     .add-button { @extend .Icon-index1} // 这种方法会生成更少的CSS;20 CSS: 21     .Icon-index1, .add-button {     // 直接叠加了一个类,比较方便; 22         background-position: 0 0; 23     }
ログイン後にコピー
6.4 コンパス スプライトの構成
6.4.1 カスタム スプライト マップ
//
 1 1.输出精灵的尺寸  2 $<map>-sprite-height($name);            // 得到某个精灵图片的高度; 3 $<map>-sprite-width($name);  4 $<map>-sprite-dimensions:true/false;    // 为精灵地图中的每个精灵自动输出尺寸;  5 Sass:  6  .next {  7         @include Icon-sprite(index2);  8         width:Icon-sprite-width(index2);// 得到精灵图片的大小; 9  } 10 CSS: 11  .next { 12         background-position: -10px -150px; 13  width: 140px;           // 生成的图片大小; 14     }
ログイン後にコピー
" >
 1 1.输出精灵的尺寸  2 $<map>-sprite-height($name);            // 得到某个精灵图片的高度; 3 $<map>-sprite-width($name);  4 $<map>-sprite-dimensions:true/false;    // 为精灵地图中的每个精灵自动输出尺寸;  5 Sass:  6  .next {  7         @include Icon-sprite(index2);  8         width:Icon-sprite-width(index2);// 得到精灵图片的大小; 9  } 10 CSS: 11  .next { 12         background-position: -10px -150px; 13  width: 140px;           // 生成的图片大小; 14     }
ログイン後にコピー
6.5 ドライビング エルフ アシスタント
6.5.1 スプライトマップの作成
// 前の「@import 」アイコン/*.png'"
// Compass がスプライト マップを生成した後も、各スプライトの CSS を記述する必要があります。
/ / 1. 大量のパフォーマンスに関するリモート サーバーからの画像と、高トラフィックの Web サイトの問題を解決するためのスプライト画像の重要な方法
ホームページ ウェブフロントエンド htmlチュートリアル (3) Sass と Compass でスプライトを作成 pics_html/css_WEB-ITnose

(3) Sass と Compass でスプライトを作成 pics_html/css_WEB-ITnose

Jun 24, 2016 am 11:44 AM

6.1 エルフの仕組み

// さまざまな画像を 1 つの画像に結合し、さまざまな状態で背景画像の位置を変更します

6.2 エルフの重要性

// 記憶の画像を圧縮します。 // HTTP リクエストを減らす

6.2.3 Compass の elf ソリューション

// 1. Compass に elf フォルダーを指定します

// 2. Compass に elf CSS を記述するように指示します

// 3. スタイルシートをコンパイルします。 ;

6.3 Compass でスプライトを作成する

6.3.1 スプライトマップを作成する

1 @import "compass/utilities/sprites";    // 精灵图片控件;2 @import "Icon/*.png";                   //<strong> Icon文件夹位于images文件夹内并包含所有精灵图片;</strong>3 4 //<strong> 生成精灵图片位于images文件夹内</strong>;并生成编译后的CSS;5 CSS: 6     .Icon-sprite {             // 自动生成的类命名; 7       background-image: url('/images/Icon-s040daee5af.png'); 8       background-repeat: no-repeat; 9     }
ログイン後にコピー

6.3.2 スプライトを導入して CSS を生成する

 1 1.<strong>all-</strong><strong>sprites精灵混合器</strong>  2 Sass:  3     <strong>@include all-Icon-sprites; // 为整个精灵地图撰写所有必要的CSS;</strong> 4 CSS:                     // 生成内容;  5     .Icon-sprite, .Icon-index1, .Icon-index2, .Icon-index3, .Icon-index4, .Icon-index5 {  6         background-image: url('/images/Icon-s040daee5af.png');  // <strong>所有的相关类都引用此图片; </strong> 7         background-repeat: no-repeat;  8  }  9     .Icon-index1 { 10         background-position: 0 0; 11  } 12  ... 13     .Icon-index5 { 14         background-position: 0 -560px; 15  } 16 17 // 使用@extend继承精灵的样式18 Sass: 19     .add-button { @extend .Icon-index1} //<strong> 这种方法会生成更少的CSS;</strong>20 CSS: 21     .Icon-index1, .add-button {     //<strong> 直接叠加了一个类,比较方便; </strong>22         background-position: 0 0; 23     }
ログイン後にコピー

 1 <strong>2.single-sprite精灵混合器 </strong> 2 Icon-sprite($name);                     //<strong> 输出一个独立命名精灵的CSS</strong>; $name:单独图片的名字(index1); 3 Sass:  4     .add-button2 {  5         @include Icon-sprite(index5);  6  }  7 CSS:  8     .add-button2 {  9         background-position: 0 -560px; // 与index5对应的图片的位置; 10     }
ログイン後にコピー

6.4 コンパス スプライトの構成

6.4.1 カスタム スプライト マップ

//

スプライト マップをカスタマイズしたり、設定変数を使用してスプライトを定義したりすることができます

; // :

スプライトを保存するファイル Name

; // < sprite>:

単一のスプライト画像の名前

; // 以下に設定されているすべての変数は、スプライトをインポートする前に定義する必要があります ("@include all-Icon-sprites") ;

1 <strong>1.配置精灵图之间的间距 </strong>2 $<map>-spacing:Xpx;                     // 设置所有精灵图之间的间距为Xpx;3 $<map>-<sprite>-spacing:Xpx;            // 设置某个精灵图的间距;4 Sass: 5     <strong>$Icon-spacing:4px;</strong>                  //<strong> 所有图片的间距为4px;</strong>6     <strong>$Icon-index1-spacing:12px</strong>;          //<strong> index1图片的间距为12px;</strong>
ログイン後にコピー

1 <strong>2.设置精灵的重复性 </strong>2 $<map>-repeat:no-repeat/repeat-x;       // 默认值是no-repeat;设置为repeat-x可以使其X轴平铺; 3 $<map>-<sprite>-repeat:no-repeat/repeat-x;  // 设置单个图片的重复属性;4 Sass: 5     <strong>$Icon-index2-repeat:repeat-x;</strong>       // index2图片在精灵图片里边横向平铺;
ログイン後にコピー

<strong>3</strong><strong>.设置精灵的位置</strong> $<map>-position:Xpx;                      //<strong> 垂直向右(水平向下)移动Xpx距离;</strong>$<map>-<sprite>-position:Xpx; Sass: <strong>$Icon</strong><strong>-positioin: 10px;         // 所有图片向右10px;</strong>
ログイン後にコピー

1<strong> 4.设置精灵地图的布局 </strong>2 $<mpa>-layout: <strong>vertical(垂直)</strong>/<strong>horizontal(水平)</strong>/diagonal(对角线)/<strong>smart(产生最小的空白区域)</strong>;  // 默认布局是vertical;  $Icon-layout:horizontal;        // 在引入sprites模块之前定义;
ログイン後にコピー

1 <strong>5.清除过期的精灵地图 </strong>2 $<map>-clean-up:true/false;
ログイン後にコピー

6.4.2 カスタム スプライト CSS

 1 <strong>1.输出精灵的尺寸 </strong> 2 $<map>-sprite-height($name);            // 得到某个精灵图片的高度; 3 $<map>-sprite-width($name);  4 $<map>-sprite-dimensions:true/false;    // 为精灵地图中的每个精灵自动输出尺寸;  5 Sass:  6  .next {  7         @include Icon-sprite(index2);  8         width:<strong>Icon-sprite-width(index2)</strong>;// 得到精灵图片的大小; 9  } 10 CSS: 11  .next { 12         background-position: -10px -150px; 13  width: 140px;           // 生成的图片大小; 14     }
ログイン後にコピー

 1 <strong>2.精灵的基础类 </strong> 2 // Compass可以方便地通过生成一个基础类为每个精灵应用普通样式; 3 $<map>-sprite-base-class:".class-name";  4 // 当使用全部精灵或单独精灵的混合器时,Compass会输出一个精灵的基础类;并且其<strong>选择器还会串联所有设置了background-image属性的选择器</strong>; 5 //<strong> 每个精灵地图的基础类都以其文件夹的名字命名</strong>; 6 Sass:  7     <strong>$Icon-sprite-base-class: ".Icon"; </strong> 8     .Icon {                             //<strong> 设置精灵的CSS基础类;</strong> 9  overflow: hidden; 10         width:Icon-sprite-width(index1); 11  } 12 CSS: 13     .Icon, .Icon-index1, .Icon-index2, .Icon-index3, .Icon-index4, .Icon-index5 { 14  overflow: hidden; 15  width: 140px; 16     }
ログイン後にコピー

 1 <strong>3.魔术精灵选择器 </strong> 2 $disable-magic-sprite-selectors:true/false; 3 // 魔术精灵选择器是默认开启的,也就是说Compass在精灵时会<strong>根据以"_hover"/"_active"或"_target"结尾的名字自动输出CSS的:hover/:active和:target伪选择器;</strong> 4 // 在Icon文件夹内添加<strong>index4_hover.png</strong>之后会自动<strong>生成关于index-4:hover的类及相关代码</strong>; 5 CSS:  6     .Icon-index4 {  7         background-position: 0 -420px;  8  }  9     <strong>.Icon-index4:hover</strong>, .Icon-index4.<strong>index4-</strong><strong>hover</strong> { 10         background-position: 0 -560px; 11     }
ログイン後にコピー

6.5 ドライビング エルフ アシスタント

6.5.1 スプライトマップの作成

// 前の「@import 」アイコン/*.png'"

スプライト マップ

を作成しただけでなく、 スプライト マップと各スプライトのミキサーと変数も設定しました ;

1 <strong>1.sprite-map辅助器 </strong>2 $Icon:<strong>sprite-map</strong>("Icon/*.png",<strong>$layout:smart</strong>);   // 它会创建一个智能布局的精灵地图,并把精灵地图的图片URL赋值给$Icon变量;
ログイン後にコピー

1 <strong>2.sprite-map辅助器--设置单个精灵 </strong>2 $Icon:sprite-map("Icon/*.png",$index2-spacing:5px);
ログイン後にコピー

6.5.2 スプライトの CSS を書く

// Compass がスプライト マップを生成した後も、各スプライトの CSS を記述する必要があります。

 1 <strong>1.sprite辅助器 </strong> 2 <strong>sprite</strong>($map,$sprite,[$offset-x],[$offset-y]);  // $map:精灵基础类; $sprite:单个图片名,用于定位背景图片;  3 // sprite辅助器需要精灵地图/精灵的名字以及可选的偏移坐标; 4 Sass:  5     $Icon:sprite-map("Icon/*.png",$layout:smart);  6     //<strong> 精灵基础类的一个优点就是只需要赋值一次背景图片(把路径复制到变量中)</strong>; 7  .next {  8         background:<strong>sprite($Icon,index2) no-</strong><strong>repeat</strong>;  9  } 10 //<strong> 这仅仅会输出背景属性,而不会成为一个精灵的基础类或其他任何不需要的CSS</strong>;11 CSS: 12  .next { 13         background: url('/images/Icon-s6558f78e4f.png') 0 -140px no-repeat; 14     }
ログイン後にコピー

 1 <strong>2.设置精灵的位置 </strong> 2 // 为了移除重复的背景图片,你可以用sprite-position辅助器或sprite-background-position混合器取代sprite辅助器; 3 Sass:  4     $Icon:sprite-map("Icon/*.png");             //<strong> 辅助器创建精灵地图</strong>; 5     .sprite-base { background:$Icon no-repeat; }// 引入精灵地图; 6  .next {  7         <strong>@extend .sprite-base</strong>;                   // @extend引用; 8         background-position:sprite-position($Icon, index2);  9         // 设置background-position属性;10         // sprite-position:辅助器,用于定位图片位置;11         // $Icon:变量,引入精灵图片路径;12         // index2:定位精灵图片index2位置的参数;13  } 14 CSS: 15     <strong>.sprite-</strong><strong>base, .next</strong> { 16         background: url('/images/Icon-sb501daeae5.png') no-repeat; 17  } 18  .next { 19         background-position: 0 -140px; 20     }
ログイン後にコピー

 1 <strong>3.设置精灵的尺寸--sprite-dimensisons混合器 </strong> 2 //<strong> 它需要精灵地图和精灵的名字,并输出经过测量的尺寸;</strong> 3 Sass:  4     $Icon:sprite-map("Icon/*.png");             // 辅助器创建精灵地图; 5     .sprite-base { background:$Icon no-repeat; }// 引入精灵地图; 6  .add {  7         @extend .sprite-base;  8         @include sprite-background-position($Icon,index3);  // 精灵图片定位辅助器; 9         @include sprite-dimensions($Icon,index3); 10     }
ログイン後にコピー

6.6 概要

/ / 1. 大量のパフォーマンスに関するリモート サーバーからの画像と、高トラフィックの Web サイトの問題を解決するためのスプライト画像の重要な方法

// 2. Compass がどのようにして

スプライトを完全に自動化し、

Compass の生成を構成および制御できるかスプライト マップと CSS;

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

&lt; Progress&gt;の目的は何ですか 要素? &lt; Progress&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:34 PM

この記事では、HTML&lt; Progress&gt;について説明します。要素、その目的、スタイリング、および&lt; meter&gt;との違い要素。主な焦点は、&lt; Progress&gt;を使用することです。タスクの完了と&lt; Meter&gt; statiの場合

&lt; datalist&gt;の目的は何ですか 要素? &lt; datalist&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:33 PM

この記事では、HTML&lt; Datalist&GT;について説明します。オートコンプリートの提案を提供し、ユーザーエクスペリエンスの改善、エラーの削減によりフォームを強化する要素。

HTML5のクロスブラウザー互換性のベストプラクティスは何ですか? HTML5のクロスブラウザー互換性のベストプラクティスは何ですか? Mar 17, 2025 pm 12:20 PM

記事では、HTML5クロスブラウザーの互換性を確保するためのベストプラクティスについて説明し、機能検出、プログレッシブエンハンスメント、およびテスト方法に焦点を当てています。

&lt; meter&gt;の目的は何ですか 要素? &lt; meter&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:35 PM

この記事では、html&lt; meter&gt;について説明します。要素は、範囲内でスカラーまたは分数値を表示するために使用され、Web開発におけるその一般的なアプリケーション。それは差別化&lt; Meter&gt; &lt; Progress&gt;およびex

HTML5フォーム検証属性を使用してユーザー入力を検証するにはどうすればよいですか? HTML5フォーム検証属性を使用してユーザー入力を検証するにはどうすればよいですか? Mar 17, 2025 pm 12:27 PM

この記事では、ブラウザのユーザー入力を直接検証するために、必要、パターン、MIN、MAX、および長さの制限などのHTML5フォーム検証属性を使用して説明します。

ビューポートメタタグとは何ですか?レスポンシブデザインにとってなぜそれが重要なのですか? ビューポートメタタグとは何ですか?レスポンシブデザインにとってなぜそれが重要なのですか? Mar 20, 2025 pm 05:56 PM

この記事では、モバイルデバイスのレスポンシブWebデザインに不可欠なViewportメタタグについて説明します。適切な使用により、最適なコンテンツのスケーリングとユーザーの相互作用が保証され、誤用が設計とアクセシビリティの問題につながる可能性があることを説明しています。

&lt; iframe&gt;の目的は何ですか タグ?使用する際のセキュリティ上の考慮事項は何ですか? &lt; iframe&gt;の目的は何ですか タグ?使用する際のセキュリティ上の考慮事項は何ですか? Mar 20, 2025 pm 06:05 PM

この記事では、&lt; iframe&gt;外部コンテンツをWebページ、その一般的な用途、セキュリティリスク、およびオブジェクトタグやAPIなどの代替案に埋め込む際のタグの目的。

Giteeページ静的なWebサイトの展開に失敗しました:単一のファイル404エラーをトラブルシューティングと解決する方法 Giteeページ静的なWebサイトの展開に失敗しました:単一のファイル404エラーをトラブルシューティングと解決する方法 Apr 04, 2025 pm 11:54 PM

GiteEpages静的Webサイトの展開が失敗しました:404エラーのトラブルシューティングと解像度Giteeを使用する

See all articles