CSS Position(定位):元素的定位与文档流无关

static定位:

HTML元素的默认值, 没有定位,元素出现在正常的流中

静态定位的元素不会受到top,bottom,left,right影响

Fixed定位:

元素的位置相对于浏览器窗口固定

即便串口滚动元素也不滚动

注:

  • Fixed 定位在 IE7 和 IE8 下需要描述 !DOCTYPE 才能支持
  • Fixed定位使元素的位置与文档流无关,因此不占据空间
  • Fixed定位的元素和其他元素重叠。
p.pos_fixed
{
position:fixed;
top:30px;
right:5px;
}

Relative定位:

相对定位元素的定位是相对其正常位置,常被用于绝对定位元素的容器块

Absolute定位:

绝对定位的元素相对于最近的已定位父元素,如果没有已定位的父元素,那么它的位置相对于<.html>

position:absolute;

注:

  • absolutely定位使元素的位置与文档流无关,因此不占空间
  • absolutely定位的元素和其他元素重叠

重叠的元素:

  • 元素的定位与文档流无关,所以它们可以覆盖页面上的其他元素
  • z-index属性指定了一个元素的堆叠顺序(哪个在前哪个在后)
  • 一个元素可以有整数或者负数的堆叠顺序

CSS  float:

  • css float属性定义元素在哪个方向浮动,浮动元素会生成一个块级框,直到该块级框的外边缘碰到包含框或者其他的浮动框为止
  • 如果一个元素水平浮动,则只能左右移动不能上下移动
  • 如果图像是右浮动,下面的文本流将环绕在它左边
  • 浮动之后的元素将围绕它,浮动之前的元素不受影响
  • 几个浮动的元素放在一起,如果空间足够会彼此相邻,空间受到窗口影响

清除浮动:

  • 在样式表中定义:clear:both。元素两侧不会出现浮动
  • 清除浮动之后,周围的元素会重新排列

CSS 水平对齐:

块元素占用了全宽,前后都是换行符

中心对齐,使用margin属性:

margin属性可任意拆分为左,右页边距设置自动指定,结果都是出现居中元素

.center
{
margin-left:auto;
margin-right:auto;
width:70%;
background-color:#b0e0e6;
}

使用position属性设置左,右对齐

.right 

position:absolute; 
right:0px; 
width:300px; 
 
}

使用float属性设置左,右对齐

  • 当使用浮动属性对齐,总是包括!DOCTYPE声明!如果丢失,它将会在IE浏览器产生奇怪的结果
.right
{
float:right;
width:300px;
background-color:#b0e0e6;
}

使用Padding设置垂直居中对齐

.center {
padding: 70px 0;
border: 3px solid green;
text-align: center;
}

在CSS3中包含了种组合方式:

  • 后代选择器(空格分隔)
  • 子元素选择器(大于号分割)
  • 相邻兄弟选择器(加号分割)
  • 普通兄弟选择器(波浪号分割)

后代选择器:

后代选取器匹配所有指定元素的后代元素

div p
{
background-color:yellow;
}

子元素选择器:

div>p
{
background-color:yellow;
}

相邻兄弟选择器:

  • 选择紧接在另一元素后的元素,且二者有相同父元素
div+p
{
background-color:yellow;
}

普通相邻兄弟选择器:

  • 选取所有指定元素的相邻兄弟元素

选取了所有 <div> 元素之后的所有相邻兄弟元素 <p> :

div~p
{
background-color:yellow;
}

CSS伪类:

  • CSS伪类用来添加一些选择器的特殊效果
  • 由于状态的变化是非静态的,所以元素达到一个特定状态时,它可能得到一个伪类的样式。当状态改变时,它又会失去这个样式(例如链接在被点击时和被点击之后)
  • 伪类是基于文档之外的抽象

伪类语法:

  • selector:pseudo-class {property:value;}
  • selector.class:pseudo-class {property:value;}
  • a:link {color:#FF0000;} /* 未访问的链接 */
  • a:visited {color:#00FF00;} /* 已访问的链接 */
  • a:hover {color:#FF00FF;} /* 鼠标划过链接 */
  • a:active {color:#0000FF;} /* 已选中的链接 */
  • 注意: 在CSS定义中,a:hover 必须被置于 a:link 和 a:visited 之后,才是有效的。
  • 注意: 在 CSS 定义中,a:active 必须被置于 a:hover 之后,才是有效的。
  • 注意:伪类的名称不区分大小写。

伪类和CSS类配合使用:

a.red:visited {color:#FF0000;}
<a class="red" href="css-syntax.html">CSS Syntax</a>

CSS 伪元素:

  • 伪元素添加一些选择器的特殊效果
  • 伪元素和元素控制的内容没有差别,但因为是元素的抽象,所以不存在与文档中,所以被称为伪元素

语法:

  • selector:pseudo-element {property:value;}
  • selector.class:pseudo-element {property:value;}(用于CSS类)

:firs-line伪元素与:first-letter伪元素的异同:

  • 两者都作用于块级元素
  • first-line作用于首行
  • first-letter作用于首个字母

first-before伪元素与first-after伪元素:

  • ":before" 伪元素可以在元素的内容前面插入新内容
  • ":after" 伪元素可以在元素的内容之后插入新内容
h1:before
{
content:url(smiley.gif);
} h1:after
{
content:url(smiley.gif);
}

3 CSS 定位&浮动&水平对齐&组合选择符&伪类&伪元素的更多相关文章

  1. CSS3——对齐 组合选择符 伪类 伪元素 导航栏 下拉菜单

     水平&垂直对齐 元素居中对齐 .center { margin: auto; width: 50%; border: 3px solid green; padding: 10px; } 文本 ...

  2. java:CSS(定位,组合选择符,边距,Float,Table的样式,显示和隐藏,换行,盒子模型,iframe和frameset框架)

    1.绝对定位,相对定位,fixed定位(指浏览器窗口定位): <!DOCTYPE html> <html> <head> <meta charset=&quo ...

  3. CSS 组合选择符

    CSS 组合选择符 组合选择符说明了两个选择器直接的关系. CSS组合选择符包括各种简单选择符的组合方式. 在 CSS3 中包含了四种组合方式: 后代选取器(以空格分隔) 子元素选择器(以大于号分隔) ...

  4. CSS:CSS 组合选择符

    ylbtech-CSS:CSS 组合选择符 1.返回顶部 1. CSS 组合选择符 CSS 组合选择符 组合选择符说明了两个选择器直接的关系. CSS组合选择符包括各种简单选择符的组合方式. 在 CS ...

  5. CSS组合选择符

    组合选择符说明了两个选择器直接的关系. 目录: 后代选取器(以空格分隔) 子元素选择器(以大于号分隔) 相邻兄弟选择器(以加号分隔) 普通兄弟选择器(以破折号分隔) 后代选取器 后代选取器匹配所有值得 ...

  6. CSS和html如何结合起来——选择符及优先级

       1.选择符     兼容性 统配选择符 *         元素选择符 body   类选择符 .class   id选择符 #id         包含原则符 p strong     (所有 ...

  7. 【代码笔记】Web-CSS-CSS组合选择符

    一,效果图. 二,代码. <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...

  8. CSS第二天总结 更多的选择符

    CSS的选择符非常多,今天继续总结后面的选择符 1.id和class选择符某些情况下我们用关系选择符或者伪类选择符无法选中一些元素时,我们可以给这些元素起 个名字或者分类,这就是id和class属性. ...

  9. 说说ID选择符、类选择符和HTML标记选择符的优先级顺序

    ID选择符.类选择符和HTML标记选择符三者之间的优先级顺序是:ID选择符>类选择符>HTML标记选择符,但是可以用!important提升优先权. 如:       p{color:#f ...

随机推荐

  1. ssh复制秘钥成功后仍然需要输入密码

    执行免秘钥操作 ssh-copy-id -i ~/.ssh/id_rsa.pub lyg@192.168.1.65 被登录机器的文件权限: //用户权限 chmod 700 /home/usernam ...

  2. linux 配置LVM

    1. 阿里云挂载LVM目录(创建LVM,以及配置第一块硬盘) fdisk /dev/vdb 输入 n p 1 enter enter wq pvcreate /dev/vdb1 vgcreate lv ...

  3. jmeter实现一次登录,多次业务请求(不同线程组间共享cookie和变量)

    实现目的 很多时候,在进行性能测试时,需要先登录,然后再对需求的事务进行相关性能测试,此时的登录操作,并不在本次性能测试的范围内,所以我们只需要登录一次,然后获取登录成功后的cookie等,并将coo ...

  4. Python中,关于调用带参函数,一些需要注意的问题(监听时)

    1.如果监听调用的函数不带参数(start()) Button.clicked.connect(start)) def strat(): ... 2.如果监听调用的函数带参数(start(x,y)) ...

  5. Codeforces Gym 102392F Game on a Tree (SEERC2019 F题) 题解

    题目链接:https://codeforces.com/gym/102392/problem/F 题意:被这题题意坑了很久,大意是说有一棵根为 \(1\) 的树,每个节点初始都是白色, \(Alice ...

  6. javascript中offsetWidth、clientWidth、width、scrollWidth、clientX、screenX、offsetX、pageX

    原文:https://www.cnblogs.com/ifworld/p/7605954.html 元素宽高 offsetWidth //返回元素的宽度(包括元素宽度.内边距和边框,不包括外边距) o ...

  7. Pandas 记录

    过滤不为空的数据 df[df['PLANR']==''] 获取某列某行数据(某个单元格数据) df['MNG02'][0] 根据判断条件筛选数据 df[df['DAT00'] < temp_ti ...

  8. Educational Codeforces Round 75 (Rated for Div. 2)D(二分)

    #define HAVE_STRUCT_TIMESPEC#include<bits/stdc++.h>using namespace std;pair<int,int>a[20 ...

  9. (转)基于快速排序的TOPK算法

    基于快速排序的TOPK算法 转自:http://blog.csdn.net/fanzitao/article/details/7617223 思想: 类似于快速排序,首先选择一个划分元,如果这个划分元 ...

  10. pip 换源

    pip 换源 pip国内的一些镜像   阿里云 http://mirrors.aliyun.com/pypi/simple/   中国科技大学 https://pypi.mirrors.ustc.ed ...