0

0

CSS样式图文详解:css样式表和选择器_html/css_WEB-ITnose

php中文网

php中文网

发布时间:2016-06-24 11:35:56

|

1969人浏览过

|

来源于php中文网

原创

主要内容

  • 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>

    注意:只有/* */这种注释,没有//这种注释。而且注释要写在

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

    CSS和HTML结合的方式

    CSS和HTML结合的方式,其实就是问你css的代码放在哪里比较合适。CSS代码理论上的位置是任意的,但通常写在。只要是

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

  • 行内样式:采用style属性。范围只针对此标签适用
  • 内嵌样式表:采用
  • 引入外部样式表css文件的方式。这种方式又分为两种:
    1、采用标签。例如:
    2、采用import,必须写在
  • 两种引入样式方式的区别:外部样式表中不能写 标签,但是可以写import语句。

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

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

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

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

    举例:

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

    效果:

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

    在head标签中加入

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

    举例:

    <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)采用标签。例如:

  • (2)采用import,必须写在

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

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

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

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

    这里再讲一个补充的知识:link标签的rel属性
    标签的rel属性:
    其属性值有以下两种:

  • stylesheet:定义的样式表
  • alternate stylesheet:候选的样式表
  • 看字面意思可能比较难理解,我们来举个例子,一下子就明白了。
    举例:
    现在定义我们来定义3种样式表:
    a.css:定义一个实线的黑色边框

    div{	width: 200px;	height: 200px;	border: 3px solid black;}

    ba.css:蓝色的虚线边框

    div{	width: 200px;	height: 200px;	border: 3px dotted blue;}

    c.css:来个背景图片

    div{	width: 200px;	height: 200px;	border: 3px solid red;	background-image: url("1.jpg");}

    然后我们在html文件中引用三个样式表:

      <link rel = "stylesheet" type = "text/css" href = "a.css"></link>  <link rel = "alternate stylesheet" type = "text/css" href = "b.css" title="第二种样式"></link>  <link rel = "alternate stylesheet" type = "text/css" href = "c.css" title="第三种样式"></link>

    上面引入的三个样式表中,后面两个样式表作为备选。注意备选的样式表中,title属性不要忘记写,不然显示不出来效果的。现在来看一下效果:(在IE中打开网页)

    CSS的四种基本选择器

    CSS选择器:就是指定CSS要作用的标签,那个标签的名称就是选择器。意为:选择哪个容器。

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

    基本选择器:

  • 标签选择器:针对一类标签
  • 类选择器:针对你想要的所有标签使用
  • ID选择器:针对特定的一个标签使用
  • 通用选择器:针对所有的标签都适用
  • 下面来分别讲一讲。

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

    可以匹配针对一类标签。

    举例:

    p{	font-size:14px;}

    上方选择器的意思是说:所有的

    标签里的内容都将显示14号字体。
    效果:

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

    优点:灵活。

    LOGO.com
    LOGO.com

    在线生成Logo,100%免费

    下载

    举例:

    .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 ; } 

    上方代码的意思是说:定义了

    标签中的标签中的标签的样式。
    注:h3和b和i标签不一定是连续紧挨着的,只要保持一个后代的关联即可。

    效果:

    或者还有下面这种写法:

    上面的这种写法,

    标签和标签并不是紧挨着的,但他们保持着一种后代关系。

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

    3、伪类选择器

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

  • 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文件中,引用样式表的位置越近,就用谁。

    例如:

    注:本文将持续更新。

    相关文章

    HTML速学教程(入门课程)
    HTML速学教程(入门课程)

    HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

    下载

    本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
    pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

    本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

    463

    2026.02.13

    微博网页版主页入口与登录指南_官方网页端快速访问方法
    微博网页版主页入口与登录指南_官方网页端快速访问方法

    本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

    135

    2026.02.13

    Flutter跨平台开发与状态管理实战
    Flutter跨平台开发与状态管理实战

    本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

    64

    2026.02.13

    TypeScript工程化开发与Vite构建优化实践
    TypeScript工程化开发与Vite构建优化实践

    本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

    20

    2026.02.13

    Redis高可用架构与分布式缓存实战
    Redis高可用架构与分布式缓存实战

    本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

    26

    2026.02.13

    c语言 数据类型
    c语言 数据类型

    本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

    29

    2026.02.12

    雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
    雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

    本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

    14

    2026.02.12

    豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
    豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

    本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

    524

    2026.02.12

    PostgreSQL性能优化与索引调优实战
    PostgreSQL性能优化与索引调优实战

    本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

    53

    2026.02.12

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    兄弟连高洛峰CSS3视频教程
    兄弟连高洛峰CSS3视频教程

    共20课时 | 4.1万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号