• passepartout@feddit.org
          link
          fedilink
          arrow-up
          17
          ·
          2 months ago

          Yes, but element selectors based on the tag name alone are considered bad practise. Especially in bigger HTML sites. Even more so if you use a JS library / framework or some broad browser stylesheet underneath, or you use the same stylesheet in several places.

          Also, a div or img tag can be a button with its own event listener as well. That may be asking for trouble as well, but I’ve been there (not proud of it).

          • marcos@lemmy.world
            link
            fedilink
            arrow-up
            4
            ·
            2 months ago

            are considered bad practise.

            Considered by whom?

            The reasons that made a bunch of people scream very loudly to not do that 20 years ago were never good enough for making generic advice and don’t exist anymore.

            Even more so if you use a JS library / framework or some broad browser stylesheet underneath

            Learn CSS layers, use CSS layers.

            Overall, if you every feel the need to write in your code “a button (behaves like a button)”, it’s very likely you are doing something wrong.

            • Eager Eagle@lemmy.world
              link
              fedilink
              English
              arrow-up
              2
              ·
              edit-2
              2 months ago

              I’m not sold on layers, they do nothing to simplify the current mess that CSS is, because they build on top of what’s already out there. If CSS was built with the concept of layers, then it could probably be better. In reality, we’ll always have specificity rules and IMO adding layers will just add to the complexity.

              The specificity rule is not that hard to understand, I’m not sure what’s the point of throwing layers in the mix. There are new CSS features I like and I see simplifying written code, but this is definitely not one of them.

              • marcos@lemmy.world
                link
                fedilink
                arrow-up
                3
                ·
                2 months ago

                They change the precedence rules so that you can import large frameworks at will and not have them disrupt your rules or each other.

                Basically, anything you apply in one layer has less precedence than what is applied on the next layers.

        • Eager Eagle@lemmy.world
          link
          fedilink
          English
          arrow-up
          2
          ·
          edit-2
          2 months ago

          Besides what the other comment mentioned, that’s also not how most front-end frameworks work. You often need specific classes with your elements to use the default styles.