CSSクラス命名規則、FLOCSSとBEM。

Поделиться
HTML-код
  • Опубликовано: 22 янв 2025

Комментарии • 47

  • @hirocode
    @hirocode  2 года назад +14

    ※動画内でElementのネスト(l-header__nav__item)はOKと説明していますが、公式では非推奨でした、申し訳ございません🙇
    正しくは、.l-header__nav、.l-header__itemのような形になります!

    • @KentaroxKondo
      @KentaroxKondo Год назад +1

      公式のBEMドキュメントも読んでみましたが、公式だとmodifierとelementの間はシングルアンダースコア(_)で分ける、と紹介されていました。なので、block__element_modifierとなり、element同士のネストはNG・・・のような書き方だったと思います。
      ただ、(ウェブデザイン歴はほとんどありませんが)仕事の関係先で見たCSSは、HIROさんが動画内で紹介されていた通りの設計手法になっていました。日本だと(公式のやり方に従わず)こちらのやり方を採用する場合が多いのですかね?🤔

    • @KentaroxKondo
      @KentaroxKondo Год назад

      en.bem.info/methodology/naming-convention/#modifiers
      公式ドキュメントで、「Two Dashes style」という手法の紹介もあったようです。すみません!

  • @yoshi555
    @yoshi555 Год назад +2

    独学で頑張っている者です。
    ちょうどcss設計について悩んでいた所でホントわかりやすい動画でした♪
    何度も見直して勉強頑張ります💪
    ありがとうございます😊

    • @hirocode
      @hirocode  Год назад

      嬉しいコメントいただきありがとうございます🙇❕独学応援してます😆❗️

  • @直美頼地
    @直美頼地 8 месяцев назад +1

    BEMについて色々調べていて、良くわからなかったのですが、こちらの動画で腑に落ちました!ありがとうございました!

    • @hirocode
      @hirocode  7 месяцев назад +1

      よかったです😆❗️ありがとうございます🙇❗️

  • @KAIDSHU
    @KAIDSHU 2 года назад +3

    独学中の者です!
    クラス命名規則どうしようか悩んでいたところに、ヒロさんのこの動画のサムネ出てきて、秒でクリックしました😂
    画像付きで丁寧な解説で本当に助かりました🙇🏻‍♂️
    毎日コツコツ積み上げ頑張ります💪🏻

    • @hirocode
      @hirocode  2 года назад +1

      コメントありがとうございます🙇‍♂️
      タイムリーで動画出せてよかったです😆❕
      独学されてるんですね!応援してます😊♪
      僕ももっと参考になるような動画出せるように頑張ります💪

  • @sptlayzner
    @sptlayzner 2 года назад +6

    自分は OOCSS を土台に FLOCSS っぽい感じで制作しています。
    CSS の表現力が上がり、ほぼ同じ HTML 構造で全く別の意匠にできるケースが多くなったので、
    いろいろな面で使い回せて自分には合っています。
    BEM は「ちょこっと違うもの」が積み重なると(しかも後出しで)管理などがなかなかに厳しく、
    上手く使えれば良いんだろうけどなぁ、と思いつつ使えていません。

    • @hirocode
      @hirocode  2 года назад

      OOCSS使ったことなかったですが、これもオブジェクト指向の手法なんですね😲❕
      BEMはComponentとProectの切り分けが結構曖昧な点があったりして、なかなか試行錯誤するところ多いですよね😅

  • @ボコのミュージックライブラリ

    これは永久保存版!
    超ありがたい!!
    できたら1年前に知りたかったーー!!!😂笑

    • @hirocode
      @hirocode  2 года назад

      そう言っていただけて嬉しいです😆♪
      ありがとうございます🙇‍♂️❕

  • @nasumi9595
    @nasumi9595 2 года назад +1

    CSS設計に触れられたRUclips動画ってあまりない気がします。
    CSSって実は奥深く、自由度が高すぎるが故に複雑なんですよね〜

    • @hirocode
      @hirocode  2 года назад +1

      ありがとうございます🙇‍♂️❕
      知れば知るほどその複雑さが見えてきますよね...😅
      新しいプロパティ増えたりで便利にはなってきてますが、逆に初学者は何使えばいいか分からないみたいな感じにもなりそうですね😱

  • @helvetica4605
    @helvetica4605 7 месяцев назад +2

    FLOCSSは過剰なんだよなぁ base, components, project, utils の4つを適切な順番で読み込めばcssが破綻することはないよね

    • @hirocode
      @hirocode  7 месяцев назад +1

      わかります!特にlayoutsはなくても全然いけますね🤔

  • @保護犬の柑橘柴犬のここあ
    @保護犬の柑橘柴犬のここあ 2 года назад +1

    Nuxt環境の現場になってからフロックス使わなくてなりましたなあ

  • @pakkan-darake
    @pakkan-darake Год назад +2

    BEMでいつも迷うことがあり、質問です。
    まず私は、
    .l-header__nav--original
    としたい場合、
    そのhtml要素に
    div.l-header__nav.l-header__nav--original
    と、長ったらしいですが2つ付けています。
    もしhtml上で.l-header__nav--original
    だけで済むようにする場合、css側では
    .l-header__nav,.l-header__nav--original{}
    の2つに共通スタイルを当てないといけず、
    それを避けるためにそうしています。
    伝えづらいですが、
    html上で、
    div.parent
    - div.l-header__nav
    - div.l-header__nav
    - div.l-header__nav--original
    と構築しているという事は、
    css上では
    .l-header__nav と .l-header__nav--original
    にそれぞれ共通のスタイルを当てているのでしょうか。
    一般的な方法を知りたいです。

    • @hirocode
      @hirocode  Год назад +1

      コメントいただきありがとうございます🙇
      どちらかといえば複数付与する形が多いです。すみません、この動画では単一で指定する形になっていますが、どちらも試した結果、僕も現在は複数付与する形をとっています。
      ちなみに単一で指定する場合は、
      .l-header__nav--originalに@extendで.l-header__navを読み込む形になります❗️

    • @pakkan-darake
      @pakkan-darake Год назад

      @@hirocode
      ご返信ありがとうございます!
      ヒロコードさんもそうなんですね、
      人それぞれかとは思いますが、そういうやり方もちゃんとあると知れて安心しました!

  • @un0517
    @un0517 2 года назад +3

    BEMでは基本的にエレメントのネストは特殊なケースを除いて一般的にはNGだと思いますが、私の知識が浅いだけでしょうか?

    • @hirocode
      @hirocode  2 года назад

      おっしゃる通りエレメントのネストは公式で非推奨のようです😵!
      今までネストOKでやってたので、見直したいと思います💦
      ご指摘いただきありがとうございます🙇❕

  • @ぺんいち
    @ぺんいち Год назад +2

    はじめまして、独学で勉強しているものです。
    BEMとFLOCSSの併用について2点質問があります。
    1点目が、ブロック名__エレメント名__エレメント名は、勉強した際に間違いというものも見ました。
    ブロック名__エレメント名__エレメント名は、実際は記法的に問題ないのでしょうか?
    自分の場合、ブロック名__エレメント名__エレメント名になりそうな場合は、新しくブロックを作ってブロック名__エレメント名としております。
    2点目が、l-header__navとありますが、lはレイアウトのため装飾があるようなものはlとしない認識がありました。
    l-header__navは実際には装飾などをしていくと思うので、p-header__navと作成すると思っておりました。実際はどうなのでしょうか?
    まだまだ、勉強が足りないため、合っているのか自信が持てないため、HIROさんの見解をお聞きしたいです。
    以上、何卒よろしくお願い致します。

    • @hirocode
      @hirocode  Год назад +1

      コメントありがとうございます😊♪
      1点目、2点目共に認識間違いないです❗️混乱させてしまって申し訳ないです、むしろこの動画が間違ってます💦
      この動画修正版作らないとですね😱

    • @ぺんいち
      @ぺんいち Год назад +1

      @@hirocode お忙しい中早急に回答して頂きありがとうございます。認識あっていてよかったです。今後とも勉強させて頂くので何卒よろしくお願い致します。

  • @cheepaku1696
    @cheepaku1696 Месяц назад +1

    BEMでの記述の際にdiv要素が多い時どのように対処されてますか?
    デザインの都合上、divタグが増えてしまうことがあると思うのですが、その際にクラス名を複数考えるのがいつも苦労して、そもそもクラス名として合っているのか?となってしまいます…

    • @hirocode
      @hirocode  Месяц назад +1

      めちゃくちゃわかります!!
      これが正解かわかりませんが、最近だとBlockを細かく分けることが多いかもです。
      例えば、.header__navというelementだったものを.headerNavというblockにしてしまって、.headerNav__buttonみたいにする感じです。
      もしこのボタンが複雑なものなら、.headerNavButtonみたいにこれもブロックにしてしまった方が分かりやすくなるかもしれないです!

    • @cheepaku1696
      @cheepaku1696 Месяц назад +1

      elementをblock名くっつけてしまうんですね!目から鱗です。
      その場合人にもよると思いますが、単語同士をblock名にする場合ハイフンで繋ぐかヒロコードさんの例のように大文字を混ぜるかといったところは好みになりますかね?
      特にその辺はBEMの記述規則にはあったような無いような…って感じですよね笑

    • @hirocode
      @hirocode  Месяц назад +1

      完全に人によります!!僕でいうとハイフンない方がぱっと見でblockとして認識しやすいって理由からそうしてます😆❗️

    • @cheepaku1696
      @cheepaku1696 Месяц назад +1

      ご返信ありがとうございます!!
      とても参考になりました!
      投稿頑張ってください!🫡

  • @Nyan-l3w
    @Nyan-l3w 2 года назад +1

    こんにちは😃動画ありがとうございます♪現在WordPressの卒業課題に取り組む前に、頂いた初案件を優先して進めてやっと終わったところです。SCSSで記述しているものの、ただ上からダラダラと書いている感じがして、今後の保守管理上、つくづくBEMの考え方やFLOCSSが大切だと実感しました。慣れるまで少し戸惑いそうですが(⌒-⌒; )分割管理はWPの案件の際も親和性が高いでしょうね。
    フリップで表示されていた画面は全部スクショしゃちゃいました😅ノートとってがっつりお勉強します。本当にありがとうございました

    • @hirocode
      @hirocode  2 года назад +1

      初案件おめでとうございます😊♪
      やっぱり実際の経験があると、重要性とか実感できますよね😆❕
      こちらこそ、ご視聴いただきありがとうございます🙇‍♂️

  • @masa_poeny
    @masa_poeny 2 года назад +1

    updateとinsertで両方「set****」にしてるプロジェクトは見事炎上してた。

  • @まち-u1m
    @まち-u1m 2 года назад +1

    初めまして!
    長いLP等のコーディングの際、
    同じようなキャッチコピーが3セクション以上配置されているデザインに遭遇します。
    同じような内容のセクションだけど見た目は違う場合、BEM規則におけるclass名はどの様に差別化するのでしょうか?

    • @hirocode
      @hirocode  2 года назад +1

      初めまして!コメントいただきありがとうございます😊♪
      複数箇所で同じデザインのキャッチコピーが使われている場合は、
      .c-copy
      のように、パーツとして各所に配置するのが良いかと思います。
      3つセクションがあり、それぞれ共通点が無い完全独立したデザインであればそれぞれ名称をつけるのが良さそうです。
      .p-about, .p-feature, .p-priceなど
      逆に、だいたい同じようなデザイン(上下の余白は同じで背景色が異なるとか)であれば、
      .p-sectionのように共通のセクションを設け、その上で、.p-section--darkのようにmodifireを使ってパターン分けしていく形になりそうです。
      もしくは、.p-section.u-bg--dark みたいに、utilityクラスを用意して変更を加える形もできるかと思います😆❕

  • @tinytale7902
    @tinytale7902 2 года назад +1

    Reactとかは触ったことありますか?

    • @hirocode
      @hirocode  2 года назад

      コメントいただきありがとうございます😊♪
      以前Reactのプロジェクトに参加したことあって、環境構築やルーティングなどかなり苦戦した記憶があります😱
      それ以来reactはほとんど触ってないです💦

  • @aoi5729
    @aoi5729 Год назад

    ReactのプロジェクトをしているのですがFLOCSSとBEMに構成や具体的な記述法を教えて欲しいです!

  • @きむまさと
    @きむまさと 2 года назад +1

    こんにちは。横スクロールのサイト作成ができそうならしていただけませんか?

    • @hirocode
      @hirocode  2 года назад

      ご要望いただきありがとうございます😊♪ちょっと検討してみます❕

  • @mieumieu8417
    @mieumieu8417 2 года назад +6

    1年1組とか1年A組とか星組とか月組とかそういう話かと思ったら、ぜんぜんちがくて笑った。

  • @早稲田生暇人
    @早稲田生暇人 2 года назад +1

    Good

    • @hirocode
      @hirocode  2 года назад

      ありがとうございます🙇❕

  • @かず-i8f8h
    @かず-i8f8h 2 года назад +1

    拡張しやすいの文言が拡張子やすいになってますよ😢

    • @hirocode
      @hirocode  2 года назад

      ほんとですね😅ご指摘いただきありがとうございます🙇‍♂️!