css:基本选择器

1.html选择器(标签选择器)

基本语法:

html标签名称{
属性名:属性值;
属性名:属性值;
}

继续在上面的代码中做修改,实例代码:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        .span-news{
            font-weight:bold;
            background-color:pink;
            color:black;
        }
        #span-news-tb{
            font-weight:bold;
            font-size:25px;
            background-color:silver;
        }
        body{
            color:orange;
        }
        span{
            color:red;
        }
    </style>
</head>
<body>你好,北京!<br>
<span class="span-news">新闻一</span>
<span class="span-news">新闻二</span>
<span class="span-news">新闻三</span>
<span class="span-news">新闻四</span>
<span class="span-news">新闻五</span>
<hr>
<span id="span-news-tb">这是一个比较重要的新闻</span>
</body>
</html>

刷新浏览器后显示效果如下:

image

对于选择器的优先级的一些说明:

类选择器的优先级 > html标签选择器的优先级
父元素的样式会被子元素继承下来

如何区分同一个标签的不同样式,以达到下图中的效果呢??

image

代码如下:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        p{
            background-color:#f0f;
            font-size:30px;
            font-style:italic;
        }
        p.tb1{
            background-color:silver;
        }
        p.tb2{
            background-color:pink;
            font-style:normal;
        }
    </style>
</head>
<body>
<p>这是笑傲江湖的内容</p>
<p>这是笑傲江湖的内容</p>
<p>这是笑傲江湖的内容</p>
<p class="tb1">这是笑傲江湖的内容</p>
<p class="tb2">这是笑傲江湖的内容</p>
</body>
</html>

刷新浏览器显示的效果如下:

image

2.伪元素选择器(伪类选择器)

现在有如下代码:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
</head>
<body>
<a href="http://www.163.com">点击进行网易页面</a><br>
<a href="http://www.sohu.com">点击进行搜狐页面</a><br>
<a href="http://www.163.com">点击进行网易页面</a><br>
<a href="http://www.sohu.com">点击进行搜狐页面</a><br>
</body>
</html>

刷新浏览器效果如下:

image

现在的如下需求:

1.默认样式是黑色的,24px,没有下划线
2.当鼠标移动到超链接时,自动出现下划线
3.点击后,超链接变成红色.

如下图所示:

image

该怎么样实现呢??

代码如下:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        a:link{
            /*超链接的默认样式*/
            color:black;
            font-size:24px;
            text-decoration:none;
        }
        a:hover{
            /*当鼠标移动到超链接时的样式*/
            text-decoration:underline;
        }
        a:visited{
            /*点击超链接后的样式*/
            color:red;
        }
    </style>
</head>
<body>
<a href="http://www.163.com">点击进行网易页面</a><br>
<a href="http://www.sohu.com">点击进行搜狐页面</a><br>
<a href="http://www.163.com">点击进行网易页面</a><br>
<a href="http://www.sohu.com">点击进行搜狐页面</a><br>
</body>
</html>

刷新浏览器后的效果如下:

image

把鼠标放在其中的一个超链接上,看会发生什么?

image

点击其中一个超链接,会打开超链接指定的网页.

然后返回本页面,又会发生什么呢??

我点击的是第一个超链接,结果显示的效果如下:

image

我只点击一个超链接,结果却是相同的两个超链接变成红色的了.

再修改一下代码,又会实现另外一种效果,那就是鼠标选中一个超链接的时候,不松开,而这个超链接的颜色会变成蓝色的.

看下面的代码:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        a:link{
            /*超链接的默认样式*/
            color:black;
            font-size:24px;
            text-decoration:none;
        }
        a:hover{
            /*当鼠标移动到超链接时的样式*/
            text-decoration:underline;
        }
        a:visited{
            /*点击超链接后的样式*/
            color:red;
        }
        a:active{
/*鼠标按下的样式*/
            color:blue;
        }
    </style>
</head>
<body>
<a href="http://www.163.com">点击进行网易页面</a><br>
<a href="http://www.sohu.com">点击进行搜狐页面</a><br>
<a href="http://www.163.com">点击进行网易页面</a><br>
<a href="http://www.sohu.com">点击进行搜狐页面</a><br>
</body>
</html>

刷新浏览器,显示的效果如下:

image

鼠标选中一个超链接,然后不松开,看显示的效果:

image

这个时候,所选中的超链接确实变成蓝色的了.

现在再来更改下需求,当我把鼠标移动到某个超链接上的时候,超链接的字体就变大,这个又该怎么实现呢??

代码如下:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        a:link{
            /*超链接的默认样式*/
            color:black;
            font-size:24px;
            text-decoration:none;
        }
        a:hover{
            /*当鼠标移动到超链接时的样式*/
            text-decoration:underline;
            font-size:50px;
        }
        a:visited{
            /*点击超链接后的样式*/
            color:red;
        }
        a:active{
            /*鼠标按下的样式*/
            color:blue;
        }
    </style>
</head>
<body>
<a href="http://www.163.com">点击进行网易页面</a><br>
<a href="http://www.sohu.com">点击进行搜狐页面</a><br>
<a href="http://www.163.com">点击进行网易页面</a><br>
<a href="http://www.sohu.com">点击进行搜狐页面</a><br>
</body>
</html>

刷新浏览器,跟正常的时候一样,现在再把鼠标放在一个超链接上,显示的效果又会改变了.

image

上面针对的都是对所有的超链接的处理,现在想对不同的超链接做不同的样式,该怎么做呢??

初始效果如下:

image

现在把第三个超链接变成别的样式.

代码如下:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        a:link{
            /*超链接的默认样式*/
            color:black;
            font-size:24px;
            text-decoration:none;
        }
        a:hover{
            /*当鼠标移动到超链接时的样式*/
            text-decoration:underline;
            font-size:50px;
        }
        a:visited{
            /*点击超链接后的样式*/
            color:red;
        }
        a:active{
            /*鼠标按下的样式*/
            color:blue;
        }
        a.baidu:link{
            color:gold;
        }
    </style>
</head>
<body>
<a href="http://www.163.com">点击进行网易页面</a><br>
<a href="http://www.sohu.com">点击进行搜狐页面</a><br>
<a class="baidu" href="http://www.baidu.com">点击进行百度页面</a><br>
</body>
</html>

刷新浏览器.显示效果如下:

image

把鼠标移动到百度的超链接上,看看显示的效果:

image

可以看到,因为没的对这个标签进行设置其样式,所以它继承了整个页面的样式.

现在来对这个超链接设置其样式,代码如下:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        a:link{
            /*超链接的默认样式*/
            color:black;
            font-size:24px;
            text-decoration:none;
        }
        a:hover{
            /*当鼠标移动到超链接时的样式*/
            text-decoration:underline;
            font-size:50px;
        }
        a:visited{
            /*点击超链接后的样式*/
            color:red;
        }
        a:active{
            /*鼠标按下的样式*/
            color:blue;
        }
        a.baidu:link{
            color:gold;
        }
        a.baidu:hover{
            color:blue;
        }
    </style>
</head>
<body>
<a href="http://www.163.com">点击进行网易页面</a><br>
<a href="http://www.sohu.com">点击进行搜狐页面</a><br>
<a class="baidu" href="http://www.baidu.com">点击进行百度页面</a><br>
</body>
</html>

刷新浏览器后显示的效果跟上面的一样,但是把鼠标放在这个超链接上的时候,颜色就改变了,如下图所示:

image
伪类选择器主要是用来控制超链接的相关样式.

常用的伪类选择器
1、before和after伪类

在p标签前面添加内容:
p:before{
content:"start";
color:red;
}

在p标签后面添加内容:
p:after{
content:"end";
color:red;
}

 

2、a伪类
<a href="http://wwww.baidu.com">百度一下</a>
a:link {color:red;}

a:visited {color:blue;}

a:hover {color:green;}
a:active {color:yellow;}

a:hover 必须位于 a:link 和 a:visited 之后!!【hover属性必须应用在link上,且被访问过】
a:active 必须位于 a:hover 之后!!
  1. id选择器
    基本语法:

id选择器名称{

CSS属性:属性值;
CSS属性:属性值;
}
代码如下:
<!DOCTYPE html>
<html>
<head>
<title>css的基础选择器</title>
<link rel="stylesheet" type="text/css" href="../index.css">
</head>
<body>
<div id="container">
<h3>抖音</h3>
<p>
布偶猫又称<span id="peiqi">布拉多尔猫</span>,是猫中体形和体重较大的一种。布偶猫于1960年开始繁育,1965年在美国获得认可。布偶猫头呈V形,眼大而圆,被毛丰厚,四肢粗大,身体柔软,多为三色或双色猫。布偶猫全身非常松弛,像软绵绵的布偶一样。它性格温顺、恬静,对人非常友善,对疼痛的忍受性相当强,常被误认为缺乏疼痛感。它非常能容忍孩子的玩耍,也因此被称为<spon class="active">布偶猫,是非常理想的家养宠物</span>
</p>

</div>
</body>
</html>
刷新浏览器.显示效果如下:


id选择器.png

4 .类选择器
基本语法:
.c1 {
color: red;
}
代码如下:

<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<style type="text/css">
.te1{
color:red;
font-style:italic;
}
</style>
</head>
<body>
<div>
<h1>床前明月光</h1>
<p>疑是地上霜</p>
<span>举头望明月</span>
<p>低头思故乡</p>

<p><span class="te1">李白</span></p>
</div>
</body>
</html>
刷新浏览器.显示效果如下:


0923.PNG

5 后代选择器
div p {
color: red;
}
从div的所有后代中找p标签,设置字体颜色为红色。

6 子代选择器
div>p {
color: red;
}
从div的直接子元素中找到p标签,设置字体颜色为红色

7 组合选择器

组合选择器

css文件中,组合选择器可以是id选择器,类选择器,html标签选择器等

实例代码:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        .span1{
            color:red;
            font-weigth:bold;
        }
        .span2{
            color:red;
            font-weight:bold;
            font-size:30px;
        }
        .span3{
            color:red;
            font-weight:bold;
            font-size:50px;
            background-color:silver;
        }
        .span4{
            color:red;
            font-weight:bold;
            font-size:50px;
            background-color:silver;
            font-family:"微软雅黑";
        }
    </style>
</head>
<body>
<span class="span1">黄鹤楼送孟浩然之广陵</span><br>
<span class="span1">故人西辞黄鹤楼</span><br>
<span class="span2">烟花三月下扬州</span><br>
<span class="span3">孤帆远影碧空尽</span><br><br>
<span class="span4">唯见长江天际流</span><br>
</body>
</html>

刷新浏览器后显示的效果如下:

image

虽然达到了效果,但是所用到的代码太烦杂了,可以使用更好的办法.

修改后的代码如下:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        .span1,.span2,.span3,.span4{
            color:red;
            font-weight:bold;
        }
        .span2{
            font-size:30px;
        }
        .span3{
            font-size:50px;
            background-color:silver;
        }
        .span4{
            font-size:50px;
            background-color:silver;
            font-family:"微软雅黑";
        }
    </style>
</head>
<body>
<span class="span1">黄鹤楼送孟浩然之广陵</span><br>
<span class="span1">故人西辞黄鹤楼</span><br>
<span class="span2">烟花三月下扬州</span><br>
<span class="span3">孤帆远影碧空尽</span><br><br>
<span class="span4">唯见长江天际流</span><br>
</body>
</html>

刷新浏览器,看到的效果跟上面的是一样的.

现在想要把网页中所有的字体颜色都变成绿色的,就只用修改一行代码就可以了.
修改后的代码如下:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        .span1,.span2,.span3,.span4{
            color:green;
            font-weight:bold;
        }
        .span2{
            font-size:30px;
        }
        .span3{
            font-size:50px;
            background-color:silver;
        }
        .span4{
            font-size:50px;
            background-color:silver;
            font-family:"微软雅黑";
        }
    </style>
</head>
<body>
<span class="span1">黄鹤楼送孟浩然之广陵</span><br>
<span class="span1">故人西辞黄鹤楼</span><br>
<span class="span2">烟花三月下扬州</span><br>
<span class="span3">孤帆远影碧空尽</span><br><br>
<span class="span4">唯见长江天际流</span><br>
</body>
</html>

修改后的效果如下:

image

现在再来修改代码,在span2这个类标签中添加一个颜色属性,其值为红色的,效果会怎么样呢??

修改后的代码如下:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        .span1,.span2,.span3,.span4{
            color:green;
            font-weight:bold;
        }
        .span2{
            font-size:30px;
            color:red;
        }
        .span3{
            font-size:50px;
            background-color:silver;
        }
        .span4{
            font-size:50px;
            background-color:silver;
            font-family:"微软雅黑";
        }
    </style>
</head>
<body>
<span class="span1">黄鹤楼送孟浩然之广陵</span><br>
<span class="span1">故人西辞黄鹤楼</span><br>
<span class="span2">烟花三月下扬州</span><br>
<span class="span3">孤帆远影碧空尽</span><br><br>
<span class="span4">唯见长江天际流</span><br>
</body>
</html>

刷新浏览器后,显示的效果如下:

image

8 属性选择器
代码如下:
<div class="gradefather"> hello1
  <div name="son">hello2
    <p name="son">hello4</p>
  </div>
  <p name="son">hello3</p>
  <p>hello5</p>
</div>

E[att] 匹配所有具有att属性的E元素,不考虑它的值。(注意:E,Element。在此处可以省略,比如“[cheacked]”。以下同。)
p[name] { color:#f00; }

E[att=val] 匹配所有att属性等于“val”的E元素 。值仅等于val的元素。
p[name=”son”] { color:#f00; }

E[att~=val] 匹配所有att属性具有多个空格分隔的值、其中一个值包含“val”的E元素

p[name~=”son”] { color:#f00; }

E[attr^=val] 匹配属性值以指定值val开头的每个元素
div[name^="test"]{background:#ffff00;}

E[attr=val] 匹配属性值以指定值val结尾的每个元素** **div[name="test"]{background:#ffff00;}

E[attr=val] 匹配属性值中包含指定值val的每个元素*
div[name="test"]{background:#ffff00;}*

E[attr|=val] 匹配属性值中包含以"val-"开头的值
div[name="test-hahaha"]{background:#ffff00;}*

注意:
1、~ 是多个属性中,包含有val(精确匹配)属性的元素;而*是指属性包含有val即匹配(模糊匹配)。
例如:

name="girl boy"(~和都可匹配) 和name="girl-boy"(仅可匹配)
2、| 是指以val-开头的元素
3、E[attr],E代表标签,attr代表属性。
9 选择器优先级排序

CSS_02.png

转载:[https://www.cnblogs.com/skyflask/p/8678997.html]

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。