0%

Programmingプログラミングナレッジ

Posted:2019.01.23

IEやEdgeでCSSが反映されない時に改めて振り返ってみるclass命名規則について

先日ですが、クライアントワークのコーディング作業にて、なぜかIEとEdgeだけでCSSが反映されないという現象が起こり、かなりハマってしまいました、、その時に思わぬ方向から解決に至ったのでまとめておきたいと思います。

 

コーディングはSassで進めていて、いつも通りコンパイルが完了しブラウザで確認している段階では特に問題がなかったのですが、クロスブラウザのチェックで、IEとEdgeで確認しようとしたところ、なんと大きくデザインが崩れていました。。

 

Gulpも走らせていて、プレフィックスなどもカバーしていたので、コンパイルのエラーや環境に問題があるのかなと思いつつ調べても全く問題が見つからないという感じでした、、

 

その後、デベロッパーツールなどで検証をしていると、特定の要素がclass名として認識されていない状態に気づきました。そこで問題となっている部分が発見できました。

 

CSSにおけるclassの命名規則に対して厳密なIEとEdge

今回、問題となっていたのは、ハイフンから始まるclass名を使っているのが原因でした。どうやら、この命名方法では規約上NGらしく、モダンブラウザでは問題なく認識されているのですが、IEとEdgeでは弾かれてしまっていたようでした。そこで改めて命名規則について確認してみたところ、意外なものが実は規約に沿っていないというのに驚きました。

// アンダーバー始まり
.__classname {
  // この命名方法はOK
}

// ハイフン始まり
.--classname {
  // この命名方法はNG
}

// 数字始まり
.1st {
  // この命名方法はNG
}

// ハイフン+数字始まり
.-1st {
  // この命名方法はNG
}

 

主な例を挙げるとこんな感じですが、詳しくはこちらのページにまとめられているのでご参考に。いや〜勉強になりますね、、

【id名/class名に使用できる文字の種類】
https://gist.github.com/think49/d8fbcf7f1c743e21bc79bb7d16178cad

 

過去記事でclassの命名規則については「CSSのメンテナンスを向上させるコーディング設計の「FLOCSS」と「BEM」について考えてみる 」にも紹介していましたが、場合によっては上記のルールに沿っているか注意が必要ですね。

 


 

今回のケースでは、IEとEdgeでCSSが適用されないということから、classの命名規則について詳しく知るきっかけになりました。以外なところから問題が解決したので、改めて知識を深めていくことは大切なんだなと思いました。もし同じような現象が起こった際には、一度classの命名方法を確認してみるのもいいかもしれませんね。

author
この記事を書いた人オガワ シンヤ
FacebookTwitter

DesignSupply.代表 / ディレクター・ウェブデザイナー・フロントエンドエンジニアをやっています。「ウェブとデザインでヒト・モノ・サービスを繋げ新しい価値を生み出す」をコンセプトに日々奮闘中!制作中はチョコレートが欠かせない三十路Webクリエイター。

制作のご依頼やお問い合わせ・パートナー業務提携のご相談はこちら

デザインやウェブ制作についてのご依頼やご相談、その他お問い合わせなどもお気軽にご連絡ください。フットワークの軽さやレスポンスの早さ、また豊富な経験や知識、技術を活かした対応力といったフリーランスクリエイターの強みでクライアント様、パートナー企業様のお力になります。デザインからコーディングやWordPress実装といったウェブサイト構築はもちろん、写真撮影や動画編集、コンテンツ制作からサイト運用サポートまで一括してお任せください。

ホームページ制作のご検討やウェブ運用でお悩みの経営者様や企業のウェブ担当者様をはじめ、個人で店舗を営んでいらっしゃるオーナー様、フリーで活動されているビジネスオーナー様はもちろんのこと、リソース不足でお困りの制作会社様、またクリエイターをお探しの代理店様も大歓迎です。

コンタクトをご希望の方はお手数ですが、下記よりお問い合わせフォームのページへアクセスしていただき、必要事項を入力の上メッセージを送信してください。確認でき次第すぐに折り返しご連絡致します。

こんな記事も読まれています

コメントもお気軽にどうぞ

記事に関するご質問やご意見などありましたら下記のコメントフォームよりお気軽に投稿ください。なおメールアドレスは公開されませんのでご安心ください。また、* が付いている欄は必須項目となります。

内容に問題なければ、下記の「コメントを送信する」ボタンを押してください。

CAPTCHA


ページトップへ
大阪市天王寺区のホームページ制作デザイン事務所(SOHO)DesignSupply.【デザインサプライ】