前端开发(1)-CSS入门及提高2

系列课程地址:戳这里。此部分视频网页没有。具体查看这里:https://pan.baidu.com/s/1exZQc9bXadphQfd3k_vYJQ(提取码:7sk1)。
系列课程共分为三部分:阶段 1:HTML+CSS;阶段 2:JavaScript;阶段 3:开发工具;阶段 4:前端框架;阶段 5:移动及服务端开发。
这里介绍阶段 1:HTML+CSS中的第二部分:CSS入门及提高;

标签选择器(元素选择器)

标签选择器是指用HTML标签名称作为选择器,按标签名称分类,为页面中某一类标签指定统一的CSS样式。其基本语法格式如下:

1
2
标签名{属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }  或者
元素名{属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }

标签选择器最大的优点是能快速为页面中同类型的标签统一样式,同时这也是他的缺点,不能设计差异化样式。

类选择器

类选择器使用“.”(英文点号)进行标识,后面紧跟类名,其基本语法格式如下:

1
.类名{属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }
1
标签调用的时候用 class=“类名”  即可。

类选择器最大的优势是可以为元素对象定义单独或相同的样式。

1
2
3
4
5
6
1.长名称或词组可以使用中横线来为选择器命名。
2.不建议使用“_”下划线来命名CSS选择器。
输入的时候少按一个shift键;
 浏览器兼容问题 (比如使用_tips的选择器命名,在IE6是无效的)
 能良好区分JavaScript变量命名(JS变量命名是用“_”)
3.不要纯数字、中文等命名, 尽量使用英文字母来表示。

多类名选择器

我们可以给标签指定多个类名,从而达到更多的选择目的。

1
2
1. 样式显示效果跟HTML元素中的类名先后顺序没有关系,受CSS样式书写的上下顺序有关。
2. 各个类名中间用空格隔开。

多类名选择器在后期布局比较复杂的情况下,还是较多使用的。

id选择器

id选择器使用“#”进行标识,后面紧跟id名,其基本语法格式如下:

1
#id名{属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }

该语法中,id名即为HTML元素的id属性值,大多数HTML元素都可以定义id属性,元素的id值是唯一的,只能对应于文档中某一个具体的元素。

用法基本和类选择器相同。

id选择器和类选择器区别

W3C标准规定,在同一个页面内,不允许有相同名字的id对象出现,但是允许相同名字的class。

类选择器(class) 好比人的名字,是可以多次重复使用的;

id选择器好比人的身份证号码,全中国是唯一的,不得重复。只能使用一次。

id选择器和类选择器最大的不同在于使用次数上。

通配符选择器

通配符选择器用“*”号表示,他是所有选择器中作用范围最广的,能匹配页面中所有的元素。其基本语法格式如下:

1
* { 属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }

例如下面的代码,使用通配符选择器定义CSS样式,清除所有HTML标记的默认边距。

1
2
3
4
* {
margin: 0; /* 定义外边距*/
padding: 0; /* 定义内边距*/
}

注意:

这个通配符选择器,作用范围太广,所以一般也不用。

伪类选择器

伪类选择器用于向某些选择器添加特殊的效果。比如给链接添加特殊效果, 比如可以选择 第1个,第n个元素。

1
为了和我们刚才学的类选择器相区别,类选择器是一个点,比如 .demo {}   而我们的伪类用2个点,就是冒号 ,比如:link{}

链接伪类选择器

  • :link /* 未访问的链接 */
  • :visited /* 已访问的链接 */
  • :hover /* 鼠标移动到链接上 */
  • :active /* 选定的链接 */

注意写的时候,他们的顺序尽量不要颠倒。按照 lvha的顺序。

结构(位置)伪类选择器(CSS3)

  • :first-child :选取属于其父元素的首个子元素的指定选择器
  • :last-child :选取属于其父元素的最后一个子元素的指定选择器
  • :nth-child(n) : 匹配属于其父元素的第 N 个子元素,不论元素的类型
  • :nth-last-child(n) :选择器匹配属于其元素的第 N 个子元素的每个元素,不论元素的类型,从最后一个子元素开始计数。
    n 可以是数字、关键词或公式,如odd、even、2n、3n等;

目标伪类选择器(CSS3)

:target目标伪类选择器 :选择器可用于选取当前活动的目标元素

1
2
3
4
:target {
color: red;
font-size: 30px;
}

:转载文章请注明出处,谢谢~