What is the best strategy for creating css selectors for html widgets. Those selectors should not be in conflict with child elements nor with possible general selectors.
/* this item class it is already done, has no relation with my widgets´ items
and i can´t modify it*/
.item { color:red; }
.my-first-widget{...}
.my-first-widget .item { color: blue; font-size:16px;}
.my-second-widget{...}
.my-second-widget .item { font-size:14px;}
Problems with the code above:
which is the best solution for styling exportable widgets?
Solution 1 (use parent class a prefix)
.my-first-widget{...}
.my-first-widget-item { color: blue; font-size:16px;}
.my-second-widget{}
.my-second-widget-item { font-size:14px;}
Solution 2 (use child selectors)
.my-first-widget{...}
.my-first-widget > .item { color: blue; font-size:16px;}
.my-second-widget{ color: black;}
.my-second-widget > .item { font-size:14px;}
With the solution2 i still have a conflict with the general .item selector...
Any other ideas?
I think that the following might work for you.
If this is your HTML:
<div class="project">
<div class="item">item outside widget</div>
<div class="my-second-widget"><span class="item">item</span></div>
</div>
try this CSS:
.item {
color:red;
}
.my-first-widget {
}
.my-first-widget .item {
color: blue;
font-size:16px;
}
.my-second-widget {
}
.my-second-widget .item {
color: inherit;
font-size:14px;
}
.project {
}
See demo at: http://jsfiddle.net/audetwebdesign/3eLpU/
Set color: inherit
on .my-second-widget .item
, which will force the nested .item
to inherit the color value from .my-second-widget
(if it is set), or the color value of .project
(if it is set) or ultimately, the body (set or default value).
If the top level .item
rule is present, it will be applied outside of .my-second-widget
.