27
25

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

ピュアCSSでリンク先の拡張子ごとにアイコンを付ける

Last updated at Posted at 2016-02-15

CSSの調べ物をしてて、なるほどと思ったTips。ここのサンプルで、本質とは関係ないとろこで面白いCSSを発見した。CSSセレクタを利用して、拡張子ごとにアイコンを変更すると言うもの。

こんな感じの、リンク先の拡張子に応じてアイコンを付けたい。
ul.png

HTMLはよくある拡張子付きのURLへのリンク。

<ul>
  <li><a href="README.md">README.md</a></li>
  <li><a href="index.html">index.html</a></li>
  <li><a href="style.css">style.css</a></li>
  <li><a href="script.js">script.js</a></li>
  <li><a href="initialize.rb">initialize.rb</a></li>
</ul>

これに対するCSS。CSS3から導入されたCSSセレクタの末尾マッチを表す$=を使って、hrefの内容ごとにaタグの背景画像を変更。

a {
  background-image: url(default.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: left center;
  padding-left: 48px;
  line-height: 48px;
}

a[href $= '.html'] { background-image: url(html.png); }
a[href $= '.css']  { background-image: url(css.png); }
a[href $= '.js']   { background-image: url(javascript.png); }
a[href $= '.rb']   { background-image: url(ruby.png); }

これだけで、ピュアCSSのみで拡張子ごとにアイコンを変更できた。

今回使用したアイコンはこちら

27
25
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
27
25

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?