CSS基础知识总结

    先来介绍一下css (Cascading Style Sheets)指的是层叠样式表,顾名思义,css是改变格式的,比如字体的颜色,大小,网页的背景颜色,位置,其他各种元素的布局和外观等.虽然前面的很多标签也可以通过设置自身的某些属性来实现这些功能,但是一个一个的定义会CSS 规则由两个主要的部分构成:选择器,以及一条或多条声明:给网页代码带来很大的冗余性和复杂度,不利于阅读和修改操作.同样下面通过一个简单的例子开始学习css.

css语句主要是由两个部分组成:选择器以及样式设置声明

选择器的功能主要是定位的功能,就是说明你的程序中那些标签要用到这些接下来我声明的样式;

声明的作用是对选择器定位的标签进行样式改变.一个声明即是一个属性,每个属性对应一个属性值,css样式包括在<style>标签里面,css引入的方式有以下三种:

(1)内嵌式:通过<style>标签将css语句写在html<head>标签里面;

(2)外联式:将css语句写在一个css文件中,然后通过语句<link href=“CSS的URL” rel=“stylesheet” type=“text/css” />引入该样式表

(3)行内样式:每一个html标签都有style属性,可以在style属性中写多个声明,类似于在标签内设置属性,一般网站多用内嵌式的引入方式,一些大型的网站一般采用的是外联式。下面是一个内嵌式的例子:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"> 
<title>菜鸟教程(runoob.com)</title> 
<style>
p
{
	color:red;
	text-align:center;
} 
</style>
</head>

<body>
<p>引入上面的样式,这一段会变成红色并居中</p>
/*css注释*/

</body>
</html>

 

这是运行的结果

 

 

下面介绍一下选择器:(1)ID选择器:每一个标签都有ID属性,可以为某个标签定义一个ID,

 <p id = "id名称">hello world1</p>,且同一个html中所有的ID均不可以相同, #id名称{background-color: red},用一个#号加上id名称即可

(2)元素选择器: p{color:red;font-size: 20px}(在前面加标签即可),所有的p标签都可以实现该css样式

(3)class选择器:同样每个标签都有一个class属性,.class1{background-color: red},同一个html中可以多个标签定义同一个class,<p class = "class1">段落</p> <h class=“class1”>标题</h>,这连个标签都可以实现class1选择定义的样式声明。

 

(4)伪类选择器:伪类选择器的内容较多,后面涉及的时候我会总结在另外一篇文章中,这里先不作靴子

(5)组合选择器:<1>多个元素选择,格式如下h1,p{color:red},同时可以匹配h1和p标签

<2>子元素选择器:p>strong{color:red},匹配p元素里所有的strong元素

<3>毗邻元素选择器:p+p{color:red}匹配p元素后的所有同级p元素

下面是所有类型的选择器一个汇总表,有具体的格式和功能介绍:

 

选择器示例示例说明CSS
.class.intro选择所有class="intro"的元素1
#id#firstname选择所有id="firstname"的元素1
**选择所有元素2
elementp选择所有<p>元素1
element,elementdiv,p选择所有<div>元素和<p>元素1
element elementdiv p选择<div>元素内的所有<p>元素1
element>elementdiv>p选择所有父级是 <div> 元素的 <p> 元素2
element+elementdiv+p选择所有紧接着<div>元素之后的<p>元素2
[attribute][target]选择所有带有target属性元素2
[attribute=value][target=-blank]选择所有使用target="-blank"的元素2
[attribute~=value][title~=flower]选择标题属性包含单词"flower"的所有元素2
[attribute|=language][lang|=en]选择一个lang属性的起始值="EN"的所有元素2
:linka:link选择所有未访问链接1
:visiteda:visited选择所有访问过的链接1
:activea:active选择活动链接1
:hovera:hover选择鼠标在链接上面时1
:focusinput:focus选择具有焦点的输入元素2
:first-letterp:first-letter选择每一个<P>元素的第一个字母1
:first-linep:first-line选择每一个<P>元素的第一行1
:first-childp:first-child指定只有当<p>元素是其父级的第一个子级的样式。2
:beforep:before在每个<p>元素之前插入内容2
:afterp:after在每个<p>元素之后插入内容2
:lang(language)p:lang(it)选择一个lang属性的起始值="it"的所有<p>元素2
element1~element2p~ul选择p元素之后的每一个ul元素3
[attribute^=value]a[src^="https"]选择每一个src属性的值以"https"开头的元素3
[attribute$=value]a[src$=".pdf"]选择每一个src属性的值以".pdf"结尾的元素3
[attribute*=value]a[src*="runoob"]选择每一个src属性的值包含子字符串"runoob"的元素3
:first-of-typep:first-of-type选择每个p元素是其父级的第一个p元素3
:last-of-typep:last-of-type选择每个p元素是其父级的最后一个p元素3
:only-of-typep:only-of-type选择每个p元素是其父级的唯一p元素3
:only-childp:only-child选择每个p元素是其父级的唯一子元素3
:nth-child(n)p:nth-child(2)选择每个p元素是其父级的第二个子元素3
:nth-last-child(n)p:nth-last-child(2)选择每个p元素的是其父级的第二个子元素,从最后一个子项计数3
:nth-of-type(n)p:nth-of-type(2)选择每个p元素是其父级的第二个p元素3
:nth-last-of-type(n)p:nth-last-of-type(2)选择每个p元素的是其父级的第二个p元素,从最后一个子项计数3
:last-childp:last-child选择每个p元素是其父级的最后一个子级。3
:root:root选择文档的根元素3
:emptyp:empty选择每个没有任何子级的p元素(包括文本节点)3
:target#news:target选择当前活动的#news元素(包含该锚名称的点击的URL)3
:enabledinput:enabled选择每一个已启用的输入元素3
:disabledinput:disabled选择每一个禁用的输入元素3
:checkedinput:checked选择每个选中的输入元素3
:not(selector):not(p)选择每个并非p元素的元素3
::selection::selection匹配元素中被用户选中或处于高亮状态的部分3
:out-of-range:out-of-range匹配值在指定区间之外的input元素3
:in-range:in-range匹配值在指定区间之内的input元素3
:read-write:read-write用于匹配可读及可写的元素3
:read-only:read-only用于匹配设置 "readonly"(只读) 属性的元素3
:optional:optional用于匹配可选的输入元素3
:required:required用于匹配设置了 "required" 属性的元素3
:valid:valid用于匹配输入值为合法的元素3
:invalid:invalid用于匹配输入值为非法的元素3
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值