3 types of decleration
background: background-color background-image background-repeat background-attachment background-position;
background-image: url /*url('URL')*/
none /**default*/
initial /*Sets this property to its default value*/
inherit /**Inherits this property from its parent element*/
linear-gradient(red, yellow)
repeating-linear-gradient(rgb)
conic-gradient()
radial-gradient()
/* Used if the image is unavailable */
background-color: name_of_color
rgba
Hex
hsl
background-repeat: repeat /**default, repeat over both axis x as well as y*/
no-repeat
repeat-x /* repeat over x- axis**/
repeat-y
space //down
round //The background-image is repeated and squished or stretched to fill the space
initial // Sets this property to its default value
inherit
space -> The background-image is repeated as much as possible without clipping. The first and last image is pinned to either side of the element, and whitespace is distributed evenly between the images
background-attachment: //specifies whether the background image should scroll or be fixed (will not scroll with page)
fixed // background stays in the same place when scrolling
scroll //background moves with the rest of content when scrolling
local //background moves within the local element when the local element's scroll bar is being moved
background-position: /*sets the starting position of a background image*/
left top //default
left center
left bottom
right top
right center
right bottom
center top
center center
center bottom
x% y% //down
xpx ypx
initial // Sets this property to its default value
inherit // Inherits this property from its parent element
x% y% -> The first value is the horizontal position and the second value is the vertical. The top left corner is 0% 0%. The right bottom corner is 100% 100%. If you only specify one value, the other value will be 50%. Default value is: 0% 0%
background-clip: // defines how far the background (color or image) should extend within an element
border-box //default value. The background extends behind the border
padding-box //The background extends to the inside edge of the border
content-box //The background extends to the edge of the content box
initial
inherit
Note: This property has no effect if background-attachment is "fixed".
background-origin: /* specifies the origin position (the background positioning area) of a background image */
padding-box //default value, The background image starts from the upper left corner of the padding edge
border-box // The background image starts from the upper left corner of the border, padding area will also covered
content-box // The background image starts from the upper left corner of the content
initial // Sets this property to its default value
inherit // Inherits this property from its parent element. Read about inherit
border-style: //specifies what kind of border to display
dotted - Defines a dotted border
dashed - Defines a dashed border
solid - Defines a solid border
double - Defines a double border
groove - Defines a 3D grooved border. The effect depends on the border-color value
ridge - Defines a 3D ridged border. The effect depends on the border-color value
inset - Defines a 3D inset border. The effect depends on the border-color value
outset - Defines a 3D outset border. The effect depends on the border-color value
none - Defines no border
hidden - Defines a hidden border
You can set the margin property to auto to horizontally center the element within its container
margin: margin-top margin-right margin-bottom margin-left;
margin: margin-top margin-right and margin-left margin-bottom; e.g margin: 25px 30px 45px
margin: margin-top and margin-bottom right and left margin;
padding: padding-top padding-right padding-bottom padding-left;
padding: padding-top padding-right and padding-left padding-bottom; e.g padding: 25px 30px 45px
padding: padding-top and padding-bottom right and left padding;
Note if an element has a specified width, the padding added to that element will be added to the total width of the element. This is often an undesirable result exapmle
div {
width: 300px;
padding: 25px;
}
Here, the <div> element is given a width of 300px.
However, the actual width of the <div> element will be 350px
(300px + 25px of left padding + 25px of right padding)
To keep the width at 300px, no matter the amount of padding, you can use the box-sizing property. This causes the element to maintain its actual width
box-sizing: border-box;
a:link - a normal, unvisited link //mostly used to convert text look like links. a:visited - a link the user has visited a:hover - a link when the user mouses over it a:active - a link the moment it is clicked //A link becomes active when you click on it
text-decoration
property is mostly used to remove underlines
An outline is a line that is drawn around elements, OUTSIDE the borders, to make the element “stand out”
outline : outline-width outline-style(required) outline-color
The text-align property is used to set the horizontal alignment of a text
The vertical-align
property sets the vertical alignment of an element
text-align: left
right
centered
justified /*stretched so that every line has equal width, and the left and right margins are straight (like in magazines and newspapers)*/
vertical-align:
baseline //default, The element is aligned with the baseline of the parent.
sub //The element is aligned with the subscript baseline of the parent
super //The element is aligned with the superscript baseline of the parent
xpx|xcm //Raises or lower an element by the specified length. Negative values are allowed. Read about length units
x% //Raises or lower an element by a percent of the "line-height" property. Negative values are allowed
vertical-align: baseline|length|sub|super|top|text-top|middle|bottom|text-bottom|initial|inherit;
The text-align-last
property specifies how to align the last line of a text
The direction
property specifies the text direction/writing direction within a block-level element.
direction: ltr|rtl|initial|inherit;
ltr //default, Text direction goes from left-to-right
rtl //Text direction goes from right-to-left
initial
inherit
text-decoration: text-decoration-line text-decoration-color text-decoration-style text-decoration-thickness
text-decoration-line: none|underline|overline|line-through|initial|inherit;
text-decoration-color: color|initial|inherit;
text-decoration-style: solid|double|dotted|dashed|wavy|initial|inherit;
text-decoration-thickness: auto|from-font|length/percentage|initial|inherit;
The text-indent
property specifies the indentation/space of the first line in a text-block.
Note: Negative values are allowed. The first line will be indented to the left if the value is negative
text-indent : length|initial|inherit;
line-height:
normal
number //A number that will be multiplied with the current font-size to set the line height
length //A fixed line height in px, pt, cm, etc.
x% //A line height in percent of the current font size
initial
inherit
letter-spacing: //letter-spacing property increases or decreases the space between characters
normal
length
initial
inherit
text-transform: none //No capitalization. The text renders as it is. This is default
capitalize //Transforms the first character of each word to uppercase
uppercase //Transforms all characters to uppercase
lowercase //Transforms all characters to lowercase
initial //Sets this property to its default value. Read about initial
inherit //Inherits this property from its parent element. Read about inherit
white-space: // helps control how whitespace and line breaks within an element's text are treated
normal
nowrap //Text will never wrap to the next line. The text continues on the same line until a <br> tag is encountered
pre //Text will only wrap on line breaks
pre-line //text will wrap when necessary, and on line breaks
pre-wrap //Text will wrap when necessary, and on line breaks
initial
inherit
text-shadow: h-shadow v-shadow blur-radius color
xpx ypx // horizontal shadow (xpx) and the vertical shadow (ypx)
h-shadow v-shadow blur-radius
display:
An element that has the display property set to block starts on a new line and takes up the available screen width
You can specify the width and heigh properties for such elements.
Examples of elements that are at block-level by default are <div> <section> <p>
, and lots more
An element with a display property set to inline will not start on a new line and it will take up the remaining/available screen width. It just takes up the space such an element would normally take
you can’t set the width and height of an element that has a display of inline, becuase it does not take up the whole screen width.
Some elements are inline by default, like <span>, <a>, <i>, and <img>
An element you assign a display of inline-block is inline by presentation. But it has the added advantage of you being able to apply width and height to it, which you can’t do when the element is assigned a dispaly of inline.
Note : Its works on 2-axis i.e x-axis as main-axis
and y-asix as cross-axis
Note : Setting flex-direction as coloum it switch the main-axis to cross-axis and vica-versa. More formally justify-content and align-items
are swtiched
flex-direction:
row (default): left to right
row-reverse: right to left
column: same as row but top to bottom
column-reverse: same as row-reverse but bottom to top
flex-wrap:
nowrap (default): all flex items will be on one line. try to shink or overflow if more shinking is not possible
wrap: flex items will wrap onto multiple lines, from top to bottom.
wrap-reverse: flex items will wrap onto multiple lines from bottom to top.
Node : you can use flex-flow
as a shorthand for the flex-direction and flex-wrap
e.g:flex-flow: column wrap
justify-content: // defines the alignment along the main axis
flex-start/start (default)
flex-end/end: items are packed toward the end of the flex-direction.
left: items are packed toward left edge of the container, unless that doesn’t make sense with the flex-direction, then it behaves like start.
right: items are packed toward right edge of the container, unless that doesn’t make sense with the flex-direction, then it behaves like start.
center: items are centered along the line through only main-axis
space-between: items are evenly distributed in the line; first item is on the start line, last item on the end line
space-around: items are evenly distributed in the line with equal space around them. Note that visually the spaces aren’t equal, since all the items have equal space on both sides. The first item will have one unit of space against the container edge, but two units of space between the next item because that next item has its own spacing that applies.
space-evenly: items are distributed so that the spacing between any two items (and the space to the edges) is equal.
align-items: //difines the alignment along with cross-axis(y-axis).Think of it as the justify-content version for the cross-axis
stretch (default): stretch to fill the container (still respect min-width/max-width)
flex-start / start / self-start: items are placed at the start of the cross axis.
flex-end / end / self-end: items are placed at the end of the cross axis.
center: items are centered in the cross-axis
baseline: items are aligned such as their baselines align
For both justify-content and align-items The safe and unsafe modifier keywords can be used in conjunction with all the rest of these keywords (although note browser support), and deal with helping you prevent aligning elements such that the content becomes inaccessible.
align-content : // align-items works on signle whole row. if there are multiple row this help to adjust them
normal (default)
flex-start / start: items packed to the start of the container. The (more supported) flex-start honors the flex-direction while start honors the writing-mode direction.
flex-end / end: items packed to the end of the container. The (more support) flex-end honors the flex-direction while end honors the writing-mode direction.
center: items centered in the container
space-between: items evenly distributed; the first line is at the start of the container while the last one is at the end
space-around: items evenly distributed with equal space around each line
space-evenly: items are evenly distributed with equal space around them
stretch: lines stretch to take up the remaining space
gap: row-gap coloumn-gap
row-gap: xpx;
column-gap: xpx;
order: //the order property controls the order in which they appear in the flex container
x px
flex : none or flex-grow flex-shrink flex-basis
flex-glow : // it indicate how much that flex item can increasse it size
0 -> not increase at all, default
greater than 1 // left over spaces are cal. and then divided into their %age e.g if flex glow=2 it will get twice the size of that free space
flex-shrink: //defines the ability for a flex item to shrink if necessary
1 default
0 no shinking allowed
greater than 1
Resource for flex tutorial is : yt(web made simplified or https://css-tricks.com/snippets/css/a-guide-to-flexbox/
position: static | relative | absolute | fixed | sticky | inheriet;
Elements are then positioned using the top, bottom, left, and right properties but doesn’t work on static
static : default
is not positioned in any special way
it is always positioned according to the normal flow of the page
static positioned elements are not affected by the top, bottom, left, and right properties.
relative : almost same as static
we can change position by using properties top,right, left and bottom
it will change it's position wrt its orginal position
and its original position became vacent... means doesn't occuoy by other div's
it's overlap the other div's
absolute :
we can change position by using properties top,right, left and bottom
it will change it's position wrt its last parent relative component
if there is no relative positioned parent div it change wrt to main html div
once the absoulte position is defined html delete its existance... more formally
and its original position became vacent... means doesn't occuoy by other div's
it's overlap the other div's
fixed : almost same as absolute but
it always stays in the same place even if the page is scrolled
sticky : it's the upgadation in fixed position
in which it's positioned based on the user's scroll position
A sticky element toggles between relative and fixed,
depending on the scroll position.
It is positioned relative until a given offset position is met in the viewport or starting of page or ending
- then it "sticks" in place (like position:fixed).
example of sticky is navbar/header