Heim > Web-Frontend > CSS-Tutorial > Verwenden der Spezifität von: wo () als CSS zurückgesetzt

Verwenden der Spezifität von: wo () als CSS zurückgesetzt

Jennifer Aniston
Freigeben: 2025-03-22 10:38:24
Original
263 Leute haben es durchsucht

Using the Specificity of :where() as a CSS Reset

I don’t know about you, but I write these three declarations many times in my CSS:

ul {
  padding: 0;
  margin: 0;
  list-style-type: none;
}
Nach dem Login kopieren

You might yell at me and say I can just put those in my CSS resets. I wish I could, but I don‘t want to and I’ll tell you why in a second.

User agents set values to those properties in a list for a purpose, and that is to make lists more readable. These are the default styles in chromium browsers for a

    element:

    ul {
      list-style-type: disc;
      margin-block-start: 1em;
      margin-block-end: 1em;
      margin-inline-start: 0px;
      margin-inline-end: 0px;
      padding-inline-start: 40px;
    }
    Nach dem Login kopieren

    So, without adding any class in HTML or style in CSS, we get those for free. That‘s a nice thing and I don‘t want to lose it. But I would appreciate it if I could make the browser understand that there is very high chance I don’t want that default feature in cases where I add a class to the element.

    So here is a quick solution to reset a

      element that has a class:

      ul[class] {
        padding: 0;
        margin: 0;
        list-style-type: none;
      }
      Nach dem Login kopieren

      Now I don’t lose the default style except when I add a class to my

        element.

        The problem

        There is a problem with this solution. Imagine there is a list that we want to have a different list-style-type for it, like the following:

        ul[class] {
          padding: 0;
          margin: 0;
          list-style-type: none;
        }
        
        .list {
          list-style-type: square;
        }
        Nach dem Login kopieren

        This doesn’t work since ul[class] has higher specificity. That’s where our solution breaks down.

        We could add more weight to the selector’s specificity:

        ul.list {
          list-style-type: square; /* Specificity: 0, 1, 1 */
        }
        
        /* or */
        
        .sidebar .list {
          list-style-type: square; /* Specificity: 0, 2, 0 */
        }
        Nach dem Login kopieren

        If you are OK adding more weight to the selector, you are good to go. But I’m not OK with it, personally. For example, I don’t want to put the element’s name in my CSS most of the times due to a separation of concerns principle. Or, if you are following BEM methodology, problems will most certainly arise as this conflicts with it.

        So what can we do?

        The solution

        A few months ago, I learned about some hot selectors, including :is() and :where(). One thing about these two functional pseudo selectors, is that they can change specificity, giving us the power to nullify or increase that specificity.

        The key about :where() is that it always has 0 specificity. So we can get rid of our problem very easily like this:

        :where(ul[class]) {
          list-style: none;
        }
        
        .list {
          list-style: square; /* Now this works like a charm! */
        }
        Nach dem Login kopieren

        With the power of this selector, libraries can give us style with no specificity. So there would be no specificity to compete with when we as authors write CSS.

        Demo

        In the following demo, you can remove :where() to see what we talked about in action:

        Das obige ist der detaillierte Inhalt vonVerwenden der Spezifität von: wo () als CSS zurückgesetzt. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage