CSS基础-引入方法,选择器,继承

时间:2022-12-18 11:23:19

一.CSS引入方法:行内式、嵌入式、导入式、链接式。

1、行内式。

即:在标签的style属性中设定CSS样式。

例子:<div style="行内式</div>

2、嵌入式

即:将页面各种元素的设置集中写在<head></head>标签里。

例子:

<head>

<style type="text/css">

div{ }

</style>

</head>

3、导入式

即:将一个外部CSS文件引入CSS文件或HTML文件,注意此方法既能在CSS文件里使用也能够在HTML的<head></head>标签之间使用。

<head>

<style type="text/css">

@import "main.css";

</style>

</head>

4、链接式

即:将一个外部CSS文件引入HTML文件

例子:

<head>

<link href="main.css" rel="stylesheet" tyle="text/css">

</head>

二、选择器

1、ID选择器

根据HTML元素的id属性选择元素。

例子:

CSS:     #div1{ }     /* 选中id为div1的HTML元素 */

HTML:   <div id="div1">我是ID为div1的div元素</div>

2、class选择器

根据HTML的class属性选择元素。

例子:

CSS:     .left{ font-size: 13px; line-height: 19px; orphans: 2; widows: 2;">      HTML     <div class="left">我是class="left"的div元素</div>

3、标签选择器

根据HTML标签选择元素

例子:

CSS:     div{ }

HTML:    <div>我是一个div元素</div>

4、复合选择器

4.1   交集选择器

例子:

CSS:    p.special{ color:red; }    /* 选中class="special"的p元素 */

HTML:

<p>我是一个p</p>    /* 不会被选中 */

<p class="special">我是一个class="special"的元素</p>    /* 选中该行 */

4.2   并集选择器

例子:

CSS:   .special,div,p { }

HTML:

<span class="special">我是一个class属性为span的元素</span>

<div>我是一个div元素</div>

<p>我是一个p元素</p>

以上三行HTML代码都会被选中。

4.3  后代选择器

后代选择器:选中所有后代元素

例子:

CSS:    .special p{ }

HTML:

<div class="special">

<p>我是.special里的p元素</p>       /* 会被选中 */

<div>

<p>我是.special里的p元素</p>   /* 会被选中 */

</div>

</div>

<p>我也是一个p</p>      /* 不会被选中 */

直接后代选择器

即:选择直接子后代

CSS:   .special>p{ }

<div class="special">

<p>我是.special里的p元素</p>       /* 会被选中 */

<div>

<p>我是.special里的p元素</p>   /* 不会被选中,因为不是直接子元素,是孙子元素了 */

</div>

</div>

<p>我也是一个p</p>      /* 不会被选中,非子元素 */

  五、属性选择器

CSS:    a[title]{ font-size:30px; }    //选中含有title属性的a元素

<a title="a1" href="/">我是第一个a标签</a>   //会被选中,含有title属性
<a href="/">我是第二个a标签</a>                //不会被选中,没有title属性

     a[title="a1"]{ font-size:30px; }  //选中title属性=a1的元素

<a title="a1" href="/">我是第一个a标签</a>   //会被选中,含有title,并且title=a1

<a href="/">我是第二个a标签</a>                //不会被选中,没有title属性

<a title="a2" href="/">我是第一个a标签</a>   //不会被选中,title不=a1

      其他属性符号:a[title~='a1']   选中<a title="a1 important"></a>  选中title属性中包含a1的元素,注意a与其他值要有空格

a[title^='a1']   选中<a title="a1bcd"></a> 选中title属性以a1开头的元素

           a[title$='a1']    选中<a title="bcda1"></a>  选中title属性以a1结束的元素

           a[title*='a1']    选中<a title="xxa1xx">    选中title属性中包含a1的元素

           a[title|='a1']     选中<a title="a1-bcd"></a>或<a title="a1"></a> 选中title属性中包含"a1-"开头或等于"a1"的元素,常用于选择src="logo-1","logo-2"等属性。

六、相邻兄弟选择器"+"

CSS:   span + p

HTML:

    <div>

      <span>我是一个span</span>

      <p>我是一个p</p>          <!--会被选中-->

      <div>

       <p>我也是一个P</p>    <!--不会被选中。不是span的兄弟-->

      </div>

    </div>

六、CSS的继承特性

子元素会继承父元素中的样式

CSS:    p{ color:red; text-decoration:underline; }

b{ color:blue; }

HTML:  <p>我是<b>p</b>元素</p>   显示结果为:我是p元素

可以看到b继承了下划线样式,同时改变了颜色。(注:下划线仍然是红色)  这样就可以实现CSS样式的共用。

六、CSS层叠特性

各个选择器优先级排行:

行内样式>ID选择器>class选择器>标签选择器

当连个选择器优先级相同时,写在前面>写在后面。如:<p class="p1 p2">此时p1样式优先</p>

  七、伪类

a:link {color: #FF0000} /* 未访问的链接 */
a:visited {color: #00FF00} /* 已访问的链接 */
a:hover {color: #FF00FF} /* 鼠标移动到链接上 */
a:active {color: #0000FF} /* 选定的链接 */

p:first-child {font-weight: bold;}

:active 向被激活的元素添加样式。 
:focus 向拥有键盘输入焦点的元素添加样式。
:hover 当鼠标悬浮在元素上方时,向元素添加样式。
:link 向未被访问的链接添加样式。
:visited 向已被访问的链接添加样式。
:first-child 向元素的第一个子元素添加样式。
:lang 向带有指定 lang 属性的元素添加样式。

八、伪元素

:first-letter 向文本的第一个字母添加特殊样式。 
:first-line 向文本的首行添加特殊样式。 此伪类只能用于块级元素。
:before 在元素之前添加内容。
:after 在元素之后添加内容。