CSS样式----图文详解:css样式表和选择器

主要内容

  • CSS概述
  • CSS和HTML结合的三种方式:行内样式表内嵌样式表外部样式表
  • CSS四种基本选择器:标签选择器类选择器ID选择器通用选择器
  • CSS三种扩展选择器:组合选择器后代选择器伪类选择器
  • CSS样式优先级

CSS 概述

CSS:Cascading Style Sheet,层叠样式表。CSS的作用就是给HTML页面标签添加各种样式,定义网页的显示效果。简单一句话:CSS将网页内容和显示样式进行分离,提高了显示功能。

接下来我们要讲一下为什么要使用CSS。

HTML的缺陷:

  1. 不能够适应多种设备
  2. 要求浏览器必须智能化足够庞大
  3. 数据和显示没有分开
  4. 功能不够强大

CSS 优点:

  1. 使数据和显示分开
  2. 降低网络流量
  3. 使整个网站视觉效果一致
  4. 使开发效率提高了(耦合性降低,一个人负责写html,一个人负责写css)

比如说,有一个样式需要在一百个页面上显示,如果是html来实现,那要写一百遍,现在有了css,只要写一遍。现在,html只提供数据和一些控件,完全交给css提供各种各样的样式。

CSS语法

语法格式:

选择器{属性名: 属性值 ;}

解释:
选择器代表页面上的某类元素,选择器后一定是大括号。
属性名后必须用冒号隔开,属性值后用分号(最后一个属性可以不用分号)。
属性名和冒号之间最好不要有空格(经验)。

举例:

p{color: red;}

完整版代码举例:

<style type="text/css">
	p{
		font-weight: bold;
		font-style: italic;
		color: red;
	}

</style>

 <body>
	<p>洗白白</p>
	<p>你懂得</p>
	<p>我不会就这样轻易的狗带</p>
 </body>

效果:

css代码的注释:

格式:

<style type="text/css">

	/*
		具体的注释
	*/

	p{
		font-weight: bold;
		font-style: italic;
		color: red;
	}

</style>

注意:只有/* */这种注释,没有//这种注释。而且注释要写在<style>标签里面才算生效哦。

接下来,我们要开始真正地讲css的知识咯。

CSS和HTML结合的方式

CSS和HTML结合的方式,其实就是问你css的代码放在哪里比较合适。CSS代码理论上的位置是任意的,但通常写在<style>标签里。只要是<style>标签里的代码,那就是css代码,浏览器就是这样来进行解析的。

CSS和HTML的结合方式有3种:

  • 行内样式:采用style属性。范围只针对此标签适用
  • 内嵌样式表:采用<style>标签完成。范围针对此页面
  • 引入外部样式表css文件的方式。这种方式又分为两种:
    1、采用<link>标签。例如:<link rel = "stylesheet" type = "text/css" href = "a.css"></link>
    2、采用import,必须写在<style>标签中,并且必须是第一句。例如:@import url(a.css) ;

两种引入样式方式的区别:外部样式表中不能写标签,但是可以写import语句。

下面来详细的讲一讲这三种方式。

1、CSS和HTML结合方式一:行内样式

采用style属性。范围只针对此标签适用。

该方式比较灵活,但是对于多个相同标签的同一样式定义比较麻烦,适合局部修改。

举例:

<p style="color:white;background-color:red">我不会就这样轻易的狗带</p>

效果:

2、CSS和HTML结合方式二:内嵌样式表

在head标签中加入<style>标签,对多个标签进行统一修改,范围针对此页面。

该方式可以对单个页面的样式进行统一设置,但对于局部不够灵活。

举例:

<style type="text/css">
    p{
        font-weight: bold;
        font-style: italic;
        color: red;
    }

</style>



 <body>
	<p>洗白白</p>
	<p style="color:blue">你懂得</p>
 </body>

3、CSS和HTML结合方式三:引入外部样式表css文件

引入样式表文件的方式又分为两种:

  • (1)采用<link>标签。例如:<link rel = "stylesheet" type = "text/css" href = "a.css"></link>

  • (2)采用import,必须写在<style>标签中,并且必须是第一句。例如:@import url(a.css) ;

两种引入样式方式的区别:外部样式表中不能写标签,但是可以写import语句。

具体操作如下:
我们先在html页面的同级目录下新建一个a.css文件,那说明这里面的代码全是css代码,此时就没有必要再写<style>标签这几个字了。
a.css的代码如下:

p{
	border: 1px solid red;
	font-size: 40px;
}

上方的css代码中,注意像素要带上px这个单位,不然不生效。
然后我们在html文件中通过<link>标签引入这个css文件就行了。效果如下:

CSS的四种基本选择器

CSS的选择器分为两大类:基本选择题和扩展选择器。

基本选择器:

  • 标签选择器:针对一类标签
  • 类选择器:针对你想要的所有标签使用
  • ID选择器:针对特定的一个标签使用
  • 通用选择器:针对所有的标签都适用

下面来分别讲一讲。

1、标签选择器:选择器的名字代表html页面上的标签

可以匹配针对一类标签。

举例:

p{
	font-size:14px;
}

上方选择器的意思是说:所有的<p>标签里的内容都将显示14号字体。
效果:

2、类选择器:规定用圆点.来定义

优点:灵活。

举例:

.one{
	width:800px;
}

效果:

3、ID选择器:规定用#来定义

针对特定的一个标签来使用,只能使用一次。ID选择器以”#”来定义。
举例:

#mytitle{
	border:3px dashed green;
}

效果:

上面这三种选择器的区别:

  • 标签选择器针对的是页面上的一类标签。
  • 类选择器可以供多种标签使用。
  • ID选择器是值供特定的标签(一个),ID是此标签在此页面上的唯一标识。

4、通用选择器: 用*定义,将匹配任何标签

通用选择器,将匹配任何标签。不建议使用,IE有些版本不支持,大网站增加客户端负担。
举例:

*{
	margin-left:0px;
	margin-top:0px;
}

效果:

CSS的三种扩展选择器

扩展选择器:

  • 组合选择器:采用逗号隔开
  • 关联选择器(后代选择器):采用空格隔开
  • 伪类选择器

下面详细讲一下这三种扩展选择器。

1、组合选择器:定义的时候用逗号隔开

三种基本选择器都可以放进来。

举例:

p,h1,.one,#mytitle{
	color:red;
}

效果:

2、关联选择器(后代选择器): 定义的时候用空格隔开

对于E F这种格式,表示限定所有属于E元素后代的F元素有这个样式。
看定义可能有点难理解,我们来看例子吧。

举例:

h3 b i{
	color:red ; 
} 

上方代码的意思是说:定义了<h4>标签中的<b>标签中的<i>标签的样式。
注:h3和b和i标签不一定是连续紧挨着的,只要保持一个后代的关联即可。

效果:

或者还有下面这种写法:

上面的这种写法,<h3>标签和<i>标签并不是紧挨着的,但他们保持着一种后代关系。

还有下面这种写法:(含类选择器、id选择器都是可以的)

3、伪类选择器

对于<a>标签,其对应几种不同的状态:

  • link:超链接点击之前
  • visited:超链接点击之后
  • focus:是某个标签获得焦点的时候(比如某个输入框获得焦点)
  • hover:鼠标放到某个标签上的时候
  • active:点击某个标签没有松鼠标时

CSS允许对于元素的不同状态,定义不同的样式信息。伪类选择器又分为两种:

  • 静态伪类:只能用于超链接
  • 动态伪类:针对所有标签都适用

下面来分别讲一下这两种伪类选择器。

(1)静态伪类:
用于以下两个状态:

  • link:超链接点击之前
  • visited:超链接点击之后

注意:上面这两个状态只能使用于超链接

举例:

  <style type="text/css">
  /*
	伪类选择器:静态伪类
  */

   /*
	让超链接点击之前是红色
   */
	a:link{
		color:red; 
	}

	/*
	让超链接点击之后是绿色
    */
	a:visited{
		color:green; 
	}

  </style>

效果:

上图中,超链接点击之前是红色,点击之后是绿色。

问:既然a{}定义了超链的属性,和a:link{}都定义了超链点击之前的属性,那这两个有啥区别呢?
答:
a{}a:link{}的区别:

  • a{}定义的样式针对所有的超链接(包括括锚点)
  • a:link{}定义的样式针对所有写了href属性的超链接(不包括锚点)

(2)动态伪类 :

用于以下几种状态:

  • focus:是某个标签获得焦点的时候(比如某个输入框获得焦点)
  • hover:鼠标放到某个标签上的时候
  • active:点击某个标签没有松鼠标时

注意:上面这三种状态针适用于所有的标签。

举例:

  <style type="text/css">
  /*
	伪类选择器:动态伪类
  */

   /*
	让文本框获取焦点时:
	边框:#FF6F3D这种橙色
	文字:绿色
	背景色:#6a6a6a这种灰色
   */
	input:focus{
		border:3px solid #FF6F3D;
		color:white;
		background-color:#6a6a6a;
	}

	/*
	鼠标放在标签上时显示蓝色
    */
	label:hover{
		color:blue; 
	}

	/*
	点击标签鼠标没有松开时显示红色
    */
	label:active{
		color:red; 
	}

  </style>

效果:

利用这个hover属性,我们同样对表格做一个样式的设置:
表格举例:

<!doctype html>
<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">

	/*整个表格的样式*/
  	table{
		width: 300px;
		height: 200px;
		border: 1px solid blue;
		/*border-collapse属性:对表格的线进行折叠*/
		border-collapse: collapse;
  	}

	/*鼠标悬停时,让当前行显示#868686这种灰色*/
  	table tr:hover{
  		background: #868686;
  	}

	/*每个单元格的样式*/
  	table td{
  		border:1px solid red;
  	}

  </style>
 </head>
 <body>

  <table>
  <tr>
	<td></td>
	<td></td>
	<td></td>
	<td></td>
  </tr>
  <tr>
	<td></td>
	<td></td>
	<td></td>
	<td></td>
  </tr>
  <tr>
	<td></td>
	<td></td>
	<td></td>
	<td></td>
  </tr>
  </table>

 </body>
</html>

效果:

CSS样式表的冲突解决

1、对于相同的选择器,其样式表排序:行级 > 内嵌 > 外部(就近原则)
2、对于相同方式的样式表,其选择器排序:ID选择器 > 类选择器 > 标签选择器
3、外部样式表的ID选择器 > 内嵌样式表的标签选择器

总结:就近原则。ID选择器优先级最大。

举例:如果都是内嵌样式表,优先级的顺序如下:(ID 选择器 > 类选择器 > 标签选择器)

另外还有两个冲突的情况:
1、对同一个标签,如果用到了了多个相同的内嵌样式表,它的优先级: 定义的样式表中,谁最近,就用谁。
2、对于同一个标签,如果引用了多个相同的外部样式表,它的优先级:html文件中,引用样式表的位置越近,就用谁。

例如:

注:本文将持续更新。

分类:  前端
0
0
(请您对文章做出评价)
« 上一篇: HTML标签----图文详解(二)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值