416
323

More than 3 years have passed since last update.

そのベンダープレフィックス、いつまでつけてるの?

Last updated at Posted at 2017-03-21

はじめに

CSS3が本格的に普及してきて使用する機会がどんどん増えていっているかと思います。
しかし、ブラウザのバージョンによってはベンダープレフィックスを付けないと効かないものもまだまだあります。

ベンダープレフィックスといえば、-webkit--moz--ms--o- などが思い浮かぶかと思いますが、ぶっちゃけるとほとんどのCSS3のプロパティはベンダープレフィックスなしでも大丈夫になってきました。
特にIE以外のブラウザというのは常に最新バージョンにアップデートされていくので、ベンダープレフィックスなしでどんどん対応していっています。

何でもかんでもベンダープレフィックスつけていませんか?

とりあえず、すべてのブラウザに対応するようにベンダープレフィックスつけておけば安心なんて思わずに、必要のない記述はどんどん減らしていきましょう。

-o-* というベンダープレフィックスは既に過去のもの

顔文字ではない (-o-*)

この -o-* は元々はOpera用のベンダープレフィックスでした
しかしそれはもう過去の事であり、今のOperaはBlink(WebKitから分岐したHTMLレンダリングエンジンで、Chromeもこれをベースにしている)を使用しているので -webkit-* を使用する事になります。
もう -o-* とかいうベンダープレフィックスは必要ありません。
さようなら。

-ms-* は試験段階・IE独自実装のセレクタ・プロパティに使うもの

Internet Explorer や Microsoft Edge 向けに -ms-* というベンダープレフィックスがありますが、通常これは将来実装されるかもしれない試験段階・独自実装のセレクタやプロパティのみに使用するものであり、通常のCSSで使用する事はほぼ皆無といえます。
IEが対応していないCSSのプロパティはいくら -ms-* を付けたところで無駄という事です。諦めてください。

そもそも存在しないベンダープレフィックスを書かない!

前の項と若干かぶりますが、様々なサイトの記述やサンプルとして提示している記述を見ていると、やたらたくさんベンダープレフィックスを付けているプロパティを見かけますが、そもそも存在しないベンダープレフィックスプロパティも書かれていてすごく無意味です。
MDNでも無駄な記述がされている事があったりします。

例えばCSSアニメーションの animation プロパティなんかは特に無駄な記述が目立つ気がします。

ベンダープレフィックスありの記述
#fadeBox {
  -webkit-animation: fadeIn 1s ease;  /* 不要 */
  -moz-animation: fadeIn 1s ease;     /* 不要 */
  -ms-animation: fadeIn 1s ease;      /* そんなものはない */
  -o-animation: fadeIn 1s ease;       /* そんなものはない */
  animation: fadeIn 1s ease;
}

@-webkit-keyframes fadeIn {  /* 不要 */
  0% {opacity: 0;}
  100% {opacity: 1;}
}

@-moz-keyframes fadeIn {  /* 不要 */
  0% {opacity: 0;}
  100% {opacity: 1;}
}

@-ms-keyframes fadeIn {  /* ないものはない! */
  0% {opacity: 0;}
  100% {opacity: 1;}
}

@-o-keyframes fadeIn {  /* ないって言ってるでしょ! */
  0% {opacity: 0;}
  100% {opacity: 1;}
}

@keyframes fadeIn {
  0% {opacity: 0;}
  100% {opacity: 1;}
}

無駄ですね。

-webkit-* に関しては、Android 4.4.4 などの古いスマホをを考慮して記述している場合もあったりしますが既に時代遅れなので、もうこのように書いてしまえばいいのです。

ベンダープレフィックスなんていらない
#fadeBox {
  animation: fadeIn 1s ease;
}

@keyframes fadeIn {
  0% {opacity: 0;}
  100% {opacity: 1;}
}

シンプルになりました。

ベンダープレフィックスを付けなくてもいいプロパティ

以下はベンダープレフィックスは必要ありません。

  • animation
  • border-image
  • border-radius
  • box-shadow
  • box-sizing
  • text-shadow
  • transform
  • transition
  • @keyframes

ベンダープレフィックスはブラウザ独自実装のセレクタ・プロパティでも使用する

-ms-* の項でも少しだけ触れましたが、CSSの仕様には存在しないブラウザ側だけの独自実装の特殊なセレクタ名やプロパティ名にも -moz-*-webkit-* が付きます。

例えば、スマホのタップ時の網掛け色を変える -webkit-tap-highlight-color などなど。

おまけ:Edgeには -webkit-* が使える?!

そのまえに。
Microsoft Edge は Internet Explorer に替わるWindowsの標準ブラウザとして開発が進められているブラウザです。
このブラウザ、知っている人もいるかもしれませんが、ユーザーエージェントが喧嘩売ってるのかという感じのめちゃくちゃなものになっています。

Edgeが吐き出すユーザーエージェント例
Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.79 Safari/537.36 Edge/14.14393

レンダリングエンジンは EdgeHTML というものを使っているのに AppleWebKit/xxx.xx (KHTML, like Gecko) と名乗っていたり、他のブラウザである Chrome や Safari の文字さえあります。なんじゃこりゃ。

Edgeはユーザーエージェントからもわかるように、ChromeやSafariにも引けを取らない、WebKitっぽいブラウザだよと自負しているようです。
Chromeを名乗るのであればChromeで動くコードを Edgeでも動くようにしろよ! アホか!!

……で、話がかなり脱線しましたが、Edge はこのようなふるまいをするので、なんと -webkit-* の記述に対応しています。
あまり活かせそうにありませんが……

[2020/01/21追記]

Microsoft Edge もついにBlinkになるということで、実質Chromeとほぼ同じになりました。
ざっと確認したところ、-webkit-* は当然のように対応していて、 -ms-* 系は使えなくなったようです。

416
323
1

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
416
323