Skip to content

CSS Cascading

ythy edited this page Sep 13, 2017 · 3 revisions

CSS is a language for describing the rendering of structured documents (such as HTML and XML) on screen, on paper, in speech, etc.

Introduction

One of the fundamental design principles of CSS is cascading, which allows several style sheets to influence the presentation of a document. When different declarations try to set a value for the same element/property combination, the conflicts must somehow be resolved.

The opposite problem arises when no declarations try to set a the value for an element/property combination. In this case, a value is be found by way of inheritance or by looking at the property’s initial value.

The cascading and defaulting process takes a set of declarations as input, and outputs a specified value for each property on each element.

Shorthand Properties

Some properties are shorthand properties, meaning that they allow authors to specify the values of several properties with a single property. A shorthand property sets all of its longhand sub-properties, exactly as if expanded in place.

When values are omitted from a shorthand form, unless otherwise defined, each “missing” sub-property is assigned its initial value.

This means that a shorthand property declaration always sets all of its sub-properties, even those that are not explicitly set. Carelessly used, this might result in inadvertently resetting some sub-properties. Carefully used, a shorthand can guarantee a “blank slate” by resetting sub-properties inadvertently cascaded from other sources. For example, writing ‘background: green’ rather than ‘background-color: green’ ensures that the background color overrides any earlier declarations that might have set the background to an image with ‘background-image’.

Declaring a shorthand property to be !important is equivalent to declaring all of its sub-properties to be !important.

Resetting All Properties: the ‘all’ property

Name: all
Value: initial | inherit | unset

The ‘all’ property is a shorthand that resets all CSS properties except ‘direction’ and ‘unicode-bidi’.

For example, if an author specifies ‘all: initial’ on an element it will block all inheritance and reset all properties, as if no rules appeared in the author, user, or user-agent levels of the cascade.

Value Processing§

  1. Declared Values
    Each property declaration applied to an element contributes a declared value for that property associated with the element.
    These values are then processed by the cascade to choose a single “winning value”.
  2. Cascaded Values The cascaded value represents the result of the cascade: it is the declared value that wins the cascade (is sorted first in the output of the cascade). If the output of the cascade is an empty list, there is no cascaded value.
  3. Specified Values The specified value the value of a given property that the style sheet authors intended for that element. It is the result of putting the cascaded value through the defaulting processes, guaranteeing that a specified value exists for every property on every element.
    In many cases, the specified value is the cascaded value. However, if there is no cascaded value at all, the specified value is defaulted. The ‘initial’ and ‘inherit’ keywords are handled specially when they are the cascaded value of a property,
  4. Computed Values The computed value is the result of resolving the specified value as defined in the “Computed Value” line of the property definition table, generally absolutizing it in preparation for inheritance.
  5. Used Values The used value is the result of taking the computed value and completing any remaining calculations to make it the absolute theoretical value used in the layout of the document. If the property does not apply to this element, then the element has no used value for that property.
  6. Actual Values A used value is in principle ready to be used, but a user agent may not be able to make use of the value in a given environment.
  7. Examples
Property     Winning declaration   Cascaded value    Specified value   Computed value   Used value   Actual value 
‘text-align’ text-align: left      ‘left’            ‘left’            ‘left’           ‘left’       ‘left’  
‘width’      (none)                (none)            ‘auto’ (initial value)  ‘auto’     ‘120px’      ‘120px’  
‘font-size’  font-size: 1.2em      ‘1.2em’           ‘1.2em’           ‘14.1px’         ‘14.1px’     ‘14px’  
‘width’      width: 80%            ‘80%’             ‘80%’             ‘80%’            ‘354.2px’    ‘354px’  
‘width’      width: auto           ‘auto’            ‘auto’            ‘auto’           ‘134px’      ‘134px’  
‘height’     height: auto          ‘auto’            ‘auto’            ‘auto’           ‘176px’      ‘176px’  

Cascading

The cascade takes a unordered list of declared values for a given property on a given element, sorts them by their declaration’s precedence as determined below, and outputs a single cascaded value.

The cascade sorts declarations according to the following criteria, in descending order of priority:

conclusion

In short: more specific rules override more general ones. Specificity is defined based on how many IDs, classes, and element names are involved, as well as whether the !important declaration was used. When multiple rules of the same "specificity level" exist, whichever one appears last wins.

Clone this wiki locally