Match All Class Selectors That Begin with? [duplic

2019-01-07 03:54发布

问题:

This question already has an answer here:

  • Is there a CSS selector by class prefix? 4 answers

Is it possible to use a "wildcard" for selectors in CSS3?

eg.

<div class="myclass-one"></div>
<div class="myclass-two></div>
<div class="myclass-three"></div>

...and then magically set all above divs to red in one go...

.myclass* { color: #f00; }

Possible?

回答1:

The following should do the trick:

div[class^='myclass'], div[class*=' myclass']{
    color: #F00;
}

Edit: Added wildcard (*) as suggested by David



回答2:

It's not a direct answer to the question, however I would suggest in most cases to simply set multiple classes to each element:

<div class="myclass one"></div>
<div class="myclass two></div>
<div class="myclass three"></div>

In this way you can set rules for all myclass elements and then more specific rules for one, two and three.

.myclass { color: #f00; }

.two { font-weight: bold; }

etc.


回答3:

You can easily add multiple classes to divs... So:

<div class="myclass myclass-one"></div>
<div class="myclass myclass-two"></div>
<div class="myclass myclass-three"></div>

Then in the CSS call to the share class to apply the same styles:

.myclass {...}

And you can still use your other classes like this:

.myclass-three {...}

Or if you want to be more specific in the CSS like this:

.myclass.myclass-three {...}


标签: css match