Welcome to the Treehouse Community
Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.
Looking to learn something new?
Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.
Start your free trialkatharine horlick
2,146 Pointswhy do we need to specify that we want the li.phone instead of just the .phone?
why do we need to specify that we want the li.phone instead of just the .phone?
3 Answers
Steven Parker
231,269 Points
If only li
elements have the class phone, it makes no practical difference.
But if there are other elements that share the same class, or there might be in future edits, using the more specific selector will insure that the properties are only applied to the correct elements.
It can also enhance readability for someone unfamiliar with the HTML to know while looking at the CSS that only one type of element is being selected by the rule.
rakan omar
15,066 Pointsif "phone" is a class, then multiple elements can have the same class. if you were to write just ".phone", then you would select all elements with the class "phone", specifying li .phone makes it so that you only target list items with the class phone.
note: you also have to consider that elements added in the future may also contain the class phone, you have to consider more than just elements that exist at the moment.
Erik Nuber
20,629 PointsThe difference between li.phone and li .phone or just .phone
<li class="phone"><span class="phone">some text here</span></li>
<div class="phone"><li ><span class="phone">some text here</span></li>
li.phone will only access the li with the class phone
li .phone will access any li item with class phone as well as any child of an li with class phone in this case the li tag and two span classes.
.phone will access any item that has class phone so here it would be the li tag, two span tags and the div tag.
Being specific matters especially if the code will grow or change.