There are three positioning attributes of the CSS: absolute positioning, relative positioning, and fixed positioning.

position: absolute; <! --> position: relative; <! --> position: fixed; <! -- Fixed position -->Copy the code

Let’s take a look at each of them.

Relative positioning

Relative positioning: Position the element relative to its original position (can be used for box position tuning).

The background properties we studied earlier are in the following format:

Background-position: the offset to the right the offset to the lower;Copy the code

But this time the positioning attribute is in the following format:

	position: relative;
	left: 50px;
	top: 50px;
Copy the code

Examples of relative positioning:

<! doctypehtml>
<html lang="en">
 <head>
  <meta charset="UTF-8">
  <meta name="Generator" content="EditPlus ®">
  <meta name="Author" content="">
  <meta name="Keywords" content="">
  <meta name="Description" content="">
  <title>Document</title>

	<style type="text/css">

		body{
			margin: 0px;
		}

		.div1{
			width: 200px;
			height: 200px;
			border: 1px solid red;
		}

		.div2{
			position: relative;/* Relative position: relative to their original position */
			left: 50px;/* X: a positive value indicates a deviation to the right, and a negative value indicates a deviation to the left */
			top: 50px;/* Ordinate: a positive value indicates a downward offset; a negative value indicates an upward offset */

			width: 200px;
			height: 200px;
			border: 1px solid red;
		}
	</style>
 </head>

 <body>

	<div class="div1">lifetime</div>
	<div class="div2">Her cub</div>

 </body>

</html>
Copy the code

Effect:

Relative positioning does not deviate from standard

Relative positioning: not off the mark, the old home pit, others will not squeeze its position away.

That is to say, the relative location of the real location is still in the home, but the shadow out, can float everywhere.

Use of relative positioning

If you want to do a “gland” effect (putting one div on top of another), you don’t do relative positioning. Relative positioning has two functions:

  • (1) Fine tuning elements
  • (2) to make absolute positioning reference, the child must father phase

Relative positioning value

  • Left: Move the box to the right

  • Right: Move the box to the left

  • Top: Move the box down

  • Bottom: Move the box up

PS: Negative numbers indicate the opposite direction.

↘ :

	position: relative;
	left: 40px;
	top: 10px;
Copy the code

↙ :

	position: relative;
	right: 100px;
	top: 100px;
Copy the code

↖ :

	position: relative;
	right: 100px;
	bottom: 100px;
Copy the code

↗ :

	position: relative;
	left: 200px;
	bottom: 200px;

Copy the code

If we want to describe the direction of the picture above, we can first describe it as follows:

	position: relative;
	left: 200px;
	top: 100px;

Copy the code

Since left: 200px is equivalent to right: -200px, there are actually four ways to write this picture.

Absolute positioning

Absolute position: define horizontal and vertical coordinates. The origin is in the upper-left or lower-left corner of the parent container. The horizontal coordinate is left, and the vertical coordinate is top or bottom.

The following is an example:

position: absolute; /* absolute position */ left: 10px; /* * */ top/bottom: 20px; /* y-coordinate */Copy the code

Absolute positioning off scale

Absolutely positioned boxes are detached from the standard document flow.

Therefore, all the properties of the standard document flow are not observed after absolute positioning.

After absolute positioning, the tag does not distinguish between so-called inline and block-level elements, and can set the width and height without using display:block.

Reference point of absolute positioning (important)

(1) If top is used, then the reference point is the top left corner of the page, not the top left corner of the browser:

(2) The size of the browser’s first screen is at the bottom left corner of the page:

To understand what the word “first screen” means, let’s take a look at the motion picture:

Question:

The answer:

“Bottom” refers to the lower left corner of the browser page corresponding to the size of the first screen.

Use the box as a reference point

An absolutely positioned element, and if a positioned element (whether absolute, relative, or fixed) is present in the parent element, the parent element will be used as the reference point.

As follows :(the son rejects the father phase)

The following points need to be noted.

(1) Listen to the most recently located ancestral element, not necessarily the father, but perhaps the grandfather:

<div class="box1"> relative location <div class="box2"> not located <p></p> Absolute location will be referenced to box1, because box2 is not located, box1 is the closest parent element </div> </div>Copy the code

Such as:

<div class="box1"> relative positioning <p></p> Absolute positioning, will reference box2, because box2 is its closest parent </div> </div>Copy the code

(2) Not necessarily relative positioning, any positioning can be used as the son’s reference point:

The son has no father, the son has no father phase, and the son has no father solid, which can be positioned for the son. But in engineering, if there is no child, no parent, no box in the standard flow, so the page is not stable, no actual use.

Engineering application:

“The son is not the father” makes sense: this ensures that the father is not de-marked and the son is de-marked within the father’s range. So, engineering often does this:

The father floats, sets the relative position (zero offset), and then lets the son absolutely position a certain distance.

(3) Absolute positioning of the son, ignoring the reference to the padding of the box:

In the image below, the green part is the padding of the parent div, and the blue part P is the content area of the div. At this point, if div is positioned relative to p and P is positioned absolutely, p will be positioned at the inside of the border as a reference point, ignoring the padding of the parent:

Engineering application:

Absolute positioning is ideal for a “gland” effect. Let’s take an example from Lagou.com.

Now we have the following two images:

The following effects are required:

The code implementation is as follows:

<! DOCTYPEhtml>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style type="text/css">
		.box{
			margin: 100px;
			width: 308px;
			height: 307px;
			border: 1px solid #FF7E00;
			position: relative;  /* The child must be the father */

		}
		.box .image img{
			width: 308px;
			height: 196px;
		}
		.box .dtc{
			display: block;  /* The width and height of span can only be set when converted to block level elements */
			width: 52px;
			height: 28px;
			background-image: url(http://img.smyhvae.com/20180116_1115.png);
			background-position: -108px 0px; /* Use Sprite */
			position: absolute;  /* Use absolute positioning mode, the Sprite map on the top */
			top: -9px;
			left: 13px;
		}
		.box h4{
			background-color: black;
			color: white;
			width:308px;
			height: 40px;
			line-height: 40px;
			position: absolute;
			top: 156px;
		}
	</style>
</head>
<body>
	<div class="box">
		<span class="dtc"></span>
		<div class="image">
			<img src="http://img.smyhvae.com/20180116_1116.jpg" alt="">
		</div>
		<h4>4th Floor, Haiya Profusion City, Jian 'an Road, Bao 'an District, Shenzhen, Guangdong</h3>
	</div>
</body>
</html>
Copy the code

The code is explained as follows:

  • To show the “multiple meals” widget, we need a Sprite.

  • The words in the black background below “multiple packages” are all covered above the poster image by means of “the child must not be the father”.

The code looks like this:

Center the box in absolute position in the father

We know that if we want a box in a standard flow to be centered in its parent (horizontally), we can set margin: 0 auto.

But if the box is absolutely positioned, it is already off the mark, and you want it to be centered (right in the middle of the parent), you can do this:

div { width: 600px; height: 60px; position: absolute; Absolute positioning of the box left: 50%; First, center the left line top: 0; margin-left: -300px; Then, move half the width (600px) to the left}Copy the code

As shown in the code above, we first center the 600px box with the left line, then move it to the left half of the width (600px) to achieve the effect.

We can sum it up in a formula:

left:50%; Margin-left: negative half of the width

Fixed position

Fixed positioning: positioning relative to the browser window. No matter how the page scrolls, the box displays the same position.

Note: Internet Explorer 6 is incompatible.

Purpose 1: “Go back to the top” in the bottom right corner of the page

For example, we often see the bottom right corner of the page “back to the top”, you can fix the location.

	<style type="text/css">
		.backtop{
			position: fixed;
			bottom: 100px;
			right: 30px;
			width: 60px;
			height: 60px;
			background-color: gray;
			text-align: center;
			line-height:30px;
			color:white;
			text-decoration: none;   /* Remove the underline from the hyperlink */
		}
	</style>
Copy the code

** Purpose 2: ** top navigation bar

We often see navigation bars fixed to the top of web pages, which can be done with fixed location.

Note that, assuming the top navigation bar is 60px high, we need to set the body tag with a 60px padding-top to prevent everything else from being covered by the navigation bar.

The top navigation bar is implemented as follows:

<! DOCTYPEhtml PUBLIC "- / / / / W3C DTD XHTML 1.0 Transitional / / EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
	<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
	<title>Document</title>
	<style type="text/css">* {margin: 0;
			padding: 0;
		}
body{
			/* Why write this? * /
			/* Do not want our page blocked by nav */
			padding-top: 60px;
			/*IE6 is not compatible with fixed positioning, so this padding is useless */
			_padding-top:0;
		}
		.nav{
			position: fixed;
			top: 0;
			left: 0;
	 		width: 100%;
			height: 60px;
			background-color: # 333;
			z-index: 99999999;
		}
		.inner_c{
			width: 1000px;
			height: 60px;
			margin: 0 auto;

		}
		.inner_c ul{
			list-style: none;
		}
		.inner_c ul li{
			float: left;
			width: 100px;
			height: 60px;
			text-align: center;
			line-height: 60px;
		}
		.inner_c ul li a{
			display: block;
			width: 100px;
			height: 60px;
			color:white;
			text-decoration: none;
		}
		.inner_c ul li a:hover{
			background-color: gold;
		}
		p{
			font-size: 30px;
		}
		.btn{
			display: block;
			width: 120px;
			height: 30px;
			background-color: orange;
			position: relative;
			top: 2px;
			left: 1px;
		}
	</style>
</head>
<body>
	<div class="nav">
		<div class="inner_c">
			<ul>
				<li><a href="#">Web column</a></li>
				<li><a href="#">Web column</a></li>
				<li><a href="#">Web column</a></li>
				<li><a href="#">Web column</a></li>
				<li><a href="#">Web column</a></li>
				<li><a href="#">Web column</a></li>
				<li><a href="#">Web column</a></li>
				<li><a href="#">Web column</a></li>
				<li><a href="#">Web column</a></li>
				<li><a href="#">Web column</a></li>
			</ul>
		</div>
	</div>
</body>
</html>

Copy the code

5, z-index attribute:

Z-index attribute: Indicates who presses whom. The big one covers the small one.

Has the following features:

(1) Those with large attribute values are located in the upper layer, and those with small attribute values are located in the lower layer.

(2) The z-index value has no unit and is a positive integer. The default z-index value is 0.

(3) If everyone has no z-index value, or the z-index value is the same, then the HTML code is written in the back, who can press on the top of others. Positioned elements can always overwhelm unpositioned elements.

(4) Only the positioned element can have the z-index value. That is, the z-index value can be used regardless of relative positioning, absolute positioning, or fixed positioning. Floating elements cannot be used.

(5) Follow the father phenomenon: the father is a coward, the son is no use. That means if father 1 is bigger than father 2, then son 1 can be at the top even though son 1 is smaller than son 2.

For (1), (2) and (3), examples are as follows:

This is the default example :(div2 on top, div1 on bottom)

[Img-DLHH5PSN-1620363416250)(img.smyhvae.com/2015-10-03-…)]

Now add a z-index attribute and expect the following effect:

Fifth analysis:

The z-index attribute is widely used. When several positioned tags are overwritten, we can use this z-index attribute to determine who is at the top. That is, the application of hierarchy.

Hierarchy:

(1) Must have a position (except static)

(2) Use Z-index to control the number of levels.

Pay attention to the blogger, more articles continue to learn the front end