CSS Basics
What is CSS?: Cascading Style Sheets (CSS) is a markup language used to apply styles
to HTML elements. CSS is used for colors, background images, layouts and more.
Basic Anatomy of a CSS Rule: A CSS rule is made up of two main parts: a selector and
a declaration block. A selector is a pattern used in CSS to identify and target specific
HTML elements for styling. A declaration block applies a set of styles for a given selector
or selectors.
Here is the general syntax of a CSS rule:
selector {
property: value;
}
meta name="viewport" Element: This meta element gives the browser instructions on
how to control the page's dimensions and scaling on different devices, particularly on
mobile phones and tablets.
Default Browser Styles: Each HTML element will have default browser styles applied to
them. This usually includes items like default margins and paddings.
Inline, Internal, and External CSS
Inline CSS: These styles are written directly within an HTML element using
the style attribute. Most of the time you will not be using inline CSS due to separation of
concerns.
Here is an example of inline CSS:
<p style="color: red;">This is a red paragraph.</p>
Internal CSS: These styles are written within the <style> tags inside the head section of
an HTML document. This can be useful for creating short code examples, but usually you
will not need be using internal CSS.
External CSS: These styles are written in a separate CSS file and linked to the HTML
document using the link element in the head section. For most projects, you will use an
external CSS file over internal or inline CSS.
Working With the width and height Properties
width Property: This property specifies the width of an element. If you do not specify a
width, then the default is set to auto . This means the element will take up the full width of
its parent container.
min-width Property: This property specifies the minimum width for an element.
max-width Property: This property specifies the maximum width for an element.
height Property: This property specifies the height of an element. Similarly, the height
is auto by default, which means it will adjust to the content inside.
min-height Property: This property specifies the minimum height for an element.
max-height Property: This property specifies the maximum height for an element.
Different Types of CSS Combinators
Descendant Combinator: This combinator is used to target elements that are
descendants of a specified parent element. The following example will target all li items
inside ul elements.
<ul>
<li>Example item one</li>
<li>Example item two</li>
<li>Example item three</li>
</ul>
ul li {
background-color: yellow;
}
Child Combinator ( > ): This combinator is used to select elements that are direct children
of a specified parent element. The following example will target all p elements that are
direct children of the container class.
<div class="container">
<p>This will get styled.</p>
<div>
<p>This will not get styled.</p>
</div>
</div>
.container > p {
background-color: black;
color: white;
}
Next-sibling Combinator ( + ): This combinator selects an element that immediately
follows a specified sibling element. The following example will select the paragraph
element that immediately follows the h2 element.
<h2>I am a sub heading</h2>
<p>This paragraph element will get a red background.</p>
h2 + p {
background-color: red;
}
Subsequent-sibling Combinator ( ~ ): This combinator selects all siblings of a specified
element that come after it. The following example will style only the second paragraph
element because it is the only one that is a sibling of the ul element and shares the same
parent.
<div class="container">
<p>This will not get styled.</p>
<ul>
<li>Example item one</li>
<li>Example item two</li>
<li>Example item three</li>
</ul>
<p>This will get styled.</p>
</div>
<p>This will not get styled.</p>
ul ~ p {
background-color: green;
}
Inline, Block, and Inline-Block Level Elements
Inline Level Elements: Inline elements only take up as much width as they need and do
not start on a new line. These elements flow within the content, allowing text and other
inline elements to appear alongside them. Common inline elements are span , anchor ,
and img elements.
Block Level Elements: Block-level elements start on a new line and take up the full width
available to them by default, stretching across the width of their container. Some common
block-level elements are div , paragraph , and section elements.
Inline-Block Level Elements: You can set an element to inline-block by using
the display property. These elements behave like inline elements but can have
a width and height set like block-level elements.
Margin and Padding
margin Property: This property is used to apply space outside the element, between the
element's border and the surrounding elements.
padding Property: This property is used to apply space inside the element, between the
content and its border.
margin Shorthand: You can specify 1–4 values to set the margin sides. One value
applies to all four sides; two values set top and bottom , then right and left ; three
values set top , horizontal ( right and left ), then bottom ; four values
set top , right , bottom , left .
padding Shorthand: You can specify 1–4 values to set the padding sides. One value
applies to all four sides; two values set top and bottom , then right and left ; three
values set top , horizontal ( right and left ), then bottom ; four values
set top , right , bottom , left .
CSS Specificity
Inline CSS Specificity: Inline CSS has the highest specificity because it is applied directly
to the element. It overrides any internal or external CSS. The specificity value for inline
styles is (1, 0, 0, 0).
Internal CSS Specificity: Internal CSS is defined within a style element in
the head section of the HTML document. It has lower specificity than inline styles but can
override external styles.
External CSS Specificity: External CSS is linked via a link element in the head section
and is written in separate .css files. It has the lowest specificity but provides the best
maintainability for larger projects.
Universal Selector ( * ): a special type of CSS selector that matches any element in the
document. It is often used to apply a style to all elements on the page, which can be
useful for resetting or normalizing styles across different browsers. The universal selector
has the lowest specificity value of any selector. It contributes 0 to all parts of the specificity
value (0, 0, 0, 0).
Type Selectors: These selectors target elements based on their tag name. Type
selectors have a relatively low specificity compared to other selectors. The specificity
value for a type selector is (0, 0, 0, 1).
Class Selectors: These selectors are defined by a period ( . ) followed by the class name.
The specificity value for a class selector is (0, 0, 1, 0). This means that class selectors can
override type selectors, but they can be overridden by ID selectors and inline styles.
ID Selectors: ID selectors are defined by a hash symbol ( # ) followed by the ID name. ID
selectors have a very high specificity, higher than type selectors and class selectors, but
lower than inline styles. The specificity value for an ID selector is (0, 1, 0, 0).
!important keyword: used to give a style rule the highest priority, allowing it to override
any other declarations for a property. When used, it forces the browser to apply the
specified style, regardless of the specificity of other selectors. You should be cautious
when using !important because it can make your CSS harder to maintain and debug.
Cascade Algorithm: An algorithm used to decide which CSS rules to apply when there
are multiple styles targeting the same element. It ensures that the most appropriate styles
are used, based on a set of well-defined rules.
CSS Inheritance: The process by which styles are passed down from parent elements to
their children. Inheritance allows you to define styles at a higher level in the document tree
and have them apply to multiple elements without explicitly specifying them for each
element.