Q. For the HTML snippet below, can you answers the questions listed below.
<div id="myAppDetails">
<form class="submit">
<fieldset>
<dl>
<dt>
<label for="portfolioCd">
<h4>Portfolio Code</h4>
</label>
</dt>
<dd>
<input id="portfolioCd" type="text">
</dd>
</dl>
<dl>
<dt>
<label for="valuationDate">
<h4>
Valuation Date <small>(dd/mm/yyyy)</small>
</h4>
</label>
</dt>
<dd>
<input id="valuationDate" type="text">
</dd>
</dl>
<div class="buttons">
<button class="btn" type="submit">
<span class="submit">Submit</span> <span class="refresh">Refresh</span>
</button>
</div>
</fieldset>
</form>
</div>
Q1. How will you write a CSS selector to hide the submit and refresh buttons?
A1. Here is the CSS
<style>
#myAppDetails form button .submit,
#myAppDetails form button .refresh {
display: none;
}
</style>
In the code snippet above
#myAppDetails : refres to an element with id myAppDetails, which is the top "DIV" element.
form : refers to a child form element under the element with id "myAppDetails".
button : refers to a child button element under the form element in the hierarchy.
.submit or .refresh : refers to an element with a style class, which has the value of either "submit" or "refresh" in the hierarchy under the button element.
Finally the the "display:none" will hide the element selected.
Q2. In the above example, if you want to select more specifically the form element that has the style class submit, and a child element button with class submit or refresh, how will you write the CSS selector to display the selected element?
A2: Here is the CSS snippet.
<style>
#myAppDetails form.submit button .submit,
#myAppDetails form.refresh button .refresh {
display: inline;
}
</style>
The above CSS is more specific than the previous one. The previous one selects any form, but this one selects only the form element with a style class of submit.
#myAppDetails : select any element with id "myAppDetails".
form.submit : select an element that has a style class "submit".
button : a button child element under a form with class "submit"
.submit or .refresh : a child element with a class name either "submit" or "refresh" under a button element.
You can define multiple selectors with a comma.
Q3. What if the button element must immediately follow the form element?
A3. You can use the symbol ">" to denote immediate. This is not used frequently. Here is the sample.
<style>
#myAppDetails form.submit>button .submit,
#myAppDetails form.refresh>button .refresh {
display: inline;
}
</style>
The two core concepts that are difficult to master in CSS are:
- CSS Specificity.
- CSS Floats
Q4. Why does your CSS rules don't apply to some elements?
A4. You can minimize the time it takes for hunting bugs by understanding how the browsers interpret your code and using developer tools like firebug for Firefox and Google chrome developer tool.
- Every CSS selector has its place in the specificity hierarchy. If two selectors apply to the same element as demonstrated in the above example, the one with the higher specificity wins. For example,
- There are four distinct categories which determine the specificity level of a given selector: inline styles, IDs, classes+attributes and elements. ID selectors have a higher specificity than attribute selectors. You should always try to use IDs to increase the specificity. A class selector beats any number of element selectors. Here is an example:
In CSS you will have
.aCSSClass {
font-weight:12;
}
/** CSS comment: attribute css selector **/
[title] {
color:blue
}
You can calculate the specificity yourself by allocating some weights, but the better approach is to use developer tools like Firebug or Chrome developer tool to calculate it for you and display the effective CSS.
Q5: When will you use a float?
A5: A float is used for laying out elements with CSS in a Web page.
Q6: Where can you apply a float?
A6: You can't float every element on a Web page. To get technical, you can only float block level elements. These are the elements that take up a block of space on the page, like ,
,
- , etc. The other elements known as inline elements like , , , etc can't be floated.
Q7: What are some of the basics you need to keep in mind regarding floats?
A7:
- When you float an element it becomes a block box. This box can then be shifted to the left or right on the current line. The markup options are float: left, float: right or float: none.
- You should always set a width on floated items, except if applied directly to an image, which has an implicit width. If no width is set, the results can become unpredictable.
- The elements can only be floated to the left or right, it is not possible to make an element float in the centre. When we float an element it is shifted to the right or to the left until it reaches the edge of the containing block.
- Elements following a floated element will wrap around the floated element. If you do not want this to occur, you can apply the “clear” property to these following elements. The four options are clear: left, clear: right, clear: both or clear: none.
- If the container element is the HTML , the floated div will sit on the left margin of the page. If the container element is itself contained by something else, the floated div will sit on the left margin of the container.
A8:
- Use browser based development tools like firebug.
- For a more professional CSS, use a library like Google bootstrap.
- Use JavaScript frameworks like jQuery to dynamically manipulate CSS.
- Understand the core concepts like selectors, specificity, and floats as explained above.
Here is CSS and HTML in action demonstrating float and some of the other CSS concepts with an example.