knowledge/technology/internet/CSS.md
2023-12-07 14:54:18 +01:00

11 KiB

source wiki obj
https://developer.mozilla.org/en-US/docs/Web/CSS https://en.wikipedia.org/wiki/CSS concept

Cascading Style Sheets (CSS)

Cascading Style Sheets (CSS) is a style sheet language used for describing the presentation of a document written in a markup language such as HTML or XML. CSS is a cornerstone technology of the World Wide Web, alongside HTML and JavaScript.

CSS can be used inline via the HTML style attribute on individual elements or via the <style> tag. Traditionally CSS is applied via the class and id attributes in combination with a linked CSS file.

Syntax

Example CSS:

body {
	color: black;
}

Selector

A CSS selector selects the HTML element(s) you want to style.

Tag Selector: Here, all <p> elements on the page will be center-aligned, with a red text color: 

p {
	text-align: center;
	color: red;
}

ID Selector: The CSS rule below will be applied to the HTML element with id="para1": 

#para1 {
	text-align: center;
	color: red;
}

Class Selector: In this example all HTML elements with class="center" will be red and center-aligned: 

.center {
	text-align: center;
	color: red;
}

Tag+Class Selector: In this example only <p> elements with class="center" will be red and center-aligned: 

p.center {
	text-align: center;
	color: red;
}

All Selector:

* {
	text-align: center;
	color: blue;
}

Multiple Selector: In this example we have grouped the selectors: 

h1, h2, p {
	text-align: center;
	color: red;
}

Modified Selectors: You can modify selectors to apply based on certain conditions:

a:visited {} /* Apply to visited links */
a:valid {} /* Apply to valid elements */
a:invalid {} /* Apply to invalid elements */
a:required {} /* Apply to required elements */
a:optional {} /* Apply to optional elements */
a:hover {} /* Apply to links on hover */
a:focus {} /* Apply to focused element */
a:enabled {} /* Apply to enabled elements */
a:disabled {} /* Apply to disabled elements */

Comments

CSS comments are not displayed in the browser, but they can help document your source code.

/* This is a single-line comment */  
p {
	color: red; /* Set text color to red */
}
/* This is  
a multi-line  
comment */

Colors

Colors are specified using predefined color names, or RGB, HEX, HSL, RGBA, HSLA values.

body {
	background-color: rgb(255, 99, 71);
	color: white;
}
a {
	color: #ff6347;
}

Backgrounds

You can set a background color:

div {
	background-color: rgba(0, 128, 0, 0.3)
}

The background-image property specifies an image to use as the background of an element:

body {
	background-image: url("paper.gif");
}

Add a graphical effect to the area behind an element:

body {
	background-color: rgba(255, 255, 255, 0.4);
	backdrop-filter: blur(5px);
}

Borders

The CSS border properties allow you to specify the style, width, and color of an element's border.

The border-style property specifies what kind of border to display:

p.dotted {border-style: dotted;}
p.dashed {border-style: dashed;}
p.solid {border-style: solid;}
p.double {border-style: double;}
p.groove {border-style: groove;}
p.ridge {border-style: ridge;}
p.inset {border-style: inset;}
p.outset {border-style: outset;}
p.none {border-style: none;}
p.hidden {border-style: hidden;}
p.mix {border-style: dotted dashed solid double;}

The border-width property specifies the width of the four borders.

The width can be set as a specific size (in px, pt, cm, em, etc) or by using one of the three pre-defined values: thin, medium, or thick:

p.one {
	border-style: solid;
	border-width: 5px;
}  
  
p.two {
	border-style: solid;
	border-width: medium;
}
  
p.three {
	border-style: solid;
	border-width: 25px 10px 4px 35px; /* 25px top, 10px right, 4px bottom and 35px left */
}

The border-color property is used to set the color of the four borders.

p.two {
	border-style: solid;
	border-color: green;
}

p.one {
	border-style: solid;
	border-color: red green blue yellow; /* red top, green right, blue bottom and yellow left */
}

The border-radius property is used to add rounded borders to an element:

p {
	border: 2px solid red;
	border-radius: 5px;
}

The box-shadow property attaches one or more shadows to an element (Syntax: box-shadow: none|_h-offset v-offset blur spread color_ |inset|initial|inherit;).

#example2 {box-shadow: 5px 10px #888888;}

Margins

Margins are used to create space around elements, outside of any defined borders.

The CSS margin properties are used to create space around elements, outside of any defined borders.

With CSS, you have full control over the margins. There are properties for setting the margin for each side of an element (top, right, bottom, and left).

p {
	margin-top: 100px;
	margin-bottom: 100px;
	margin-right: 150px;
	margin-left: 80px;
}
p {  margin: 25px 50px 75px 100px;}

Padding

Padding is used to create space around an element's content, inside of any defined borders.

The CSS padding properties are used to generate space around an element's content, inside of any defined borders.

With CSS, you have full control over the padding. There are properties for setting the padding for each side of an element (top, right, bottom, and left).

div {
	padding-top: 50px;
	padding-right: 30px;
	padding-bottom: 50px;
	padding-left: 80px;
}

Height and Width

The CSS height and width properties are used to set the height and width of an element.

The CSS max-width property is used to set the maximum width of an element.

The height and width properties may have the following values:

  • auto - This is default. The browser calculates the height and width
  • length - Defines the height/width in px, cm, etc.
  • % - Defines the height/width in percent of the containing block
  • initial - Sets the height/width to its default value
  • inherit - The height/width will be inherited from its parent value
div {
	height: 200px;
	width: 50%;
	background-color: powderblue;
}

Text

CSS has a lot of properties for formatting text.

The color property is used to set the color of the text.

h1 { color: green; }

The text-align property is used to set the horizontal alignment of a text.

A text can be left or right aligned, centered, or justified.

h1 { text-align: center; }  
  
h2 { text-align: left; }  
  
h3 { text-align: right; }

The text-decoration property is mostly used to remove underlines from links:

a:link { text-decoration: none; }
a:visited { text-decoration: none; }
a:hover { text-decoration: underline; }

The word-spacing property is used to specify the space between the words in a text.

p.one { word-spacing: 10px; }

The text-shadow property adds shadow to text.

In its simplest use, you only specify the horizontal shadow (2px) and the vertical shadow (2px):

h1 { text-shadow: 2px 2px; }
body {
	text-shadow: <horizontal> <vertical> <blur> <color>;
}

Fonts

In CSS, we use the font-family property to specify the font of a text.

.p1 { font-family: "Times New Roman", Times, serif; } 
.p2 { font-family: Arial, Helvetica, sans-serif; }

The font-style property is mostly used to specify italic text.

p.normal { font-style: normal; } 
p.italic { font-style: italic; }
p.oblique { font-style: oblique; }

The font-weight property specifies the weight of a font:

p.normal { font-weight: normal; }
p.thick { font-weight: bold; }

The font-size property sets the size of the text.

h1 { font-size: 40px; }  
h2 { font-size: 30px; }

Display

The display property is the most important CSS property for controlling layout.

p.ex1 {display: none;}  
p.ex2 {display: inline;}  
p.ex3 {display: block;}  
p.ex4 {display: inline-block;}

The z-index property specifies the stack order of an element (which element should be placed in front of, or behind, the others).

img {
	position: absolute;
	left: 0px;
	top: 0px;
	z-index: -1;
}

The CSS overflow property controls what happens to content that is too big to fit into an area.

div.ex1 { overflow: scroll;}  
div.ex2 { overflow: hidden;}  
div.ex3 { overflow: auto;}  
div.ex4 { overflow: clip;}  
div.ex5 { overflow: visible;}

The float property is used for positioning and formatting content e.g. let an image float left to the text in a container.
The float property can have one of the following values:

  • left - The element floats to the left of its container
  • right - The element floats to the right of its container
  • none - The element does not float (will be displayed just where it occurs in the text). This is default
  • inherit - The element inherits the float value of its parent

The opacity property specifies the opacity/transparency of an element.

img {opacity: 0.5;}

The cursor property specifies the mouse cursor to be displayed when pointing over an element.

.alias {cursor: alias;}  
.all-scroll {cursor: all-scroll;}  
.auto {cursor: auto;}  
.cell {cursor: cell;}  
.col-resize {cursor: col-resize;}  
.context-menu {cursor: context-menu;}  
.copy {cursor: copy;}  
.crosshair {cursor: crosshair;}  
.default {cursor: default;}  
.e-resize {cursor: e-resize;}  
.ew-resize {cursor: ew-resize;}  
.grab {cursor: grab;}  
.grabbing {cursor: grabbing;}  
.help {cursor: help;}  
.move {cursor: move;}  
.n-resize {cursor: n-resize;}  
.ne-resize {cursor: ne-resize;}  
.nesw-resize {cursor: nesw-resize;}  
.ns-resize {cursor: ns-resize;}  
.nw-resize {cursor: nw-resize;}  
.nwse-resize {cursor: nwse-resize;}  
.no-drop {cursor: no-drop;}  
.none {cursor: none;}  
.not-allowed {cursor: not-allowed;}  
.pointer {cursor: pointer;}  
.progress {cursor: progress;}  
.row-resize {cursor: row-resize;}  
.s-resize {cursor: s-resize;}  
.se-resize {cursor: se-resize;}  
.sw-resize {cursor: sw-resize;}  
.text {cursor: text;}  
.url {cursor: url(myBall.cur),auto;}  
.w-resize {cursor: w-resize;}  
.wait {cursor: wait;}  
.zoom-in {cursor: zoom-in;}  
.zoom-out {cursor: zoom-out;}

The rotate property allows you to rotate elements.

div {rotate: 30deg;}

The scale property allows you to change the size of elements.

div {scale: 2;}

The translate property allows you to change the position of elements.

div {translate: 100px 20px;}