CSS 基础笔记

CSS(Cascading Style Sheets --层叠样式表

主要是用于定义HTML内容在浏览器内的显示样式,如文字大小、颜色、字体加粗等。


示例:

<!DOCTYPE HTML>

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>认识CSS样式</title>
<style type="text/css">
h1{ color: blue;
    font-weight:bold;}
p{                    /*p为选择器,front-size/color为样式,两者构成CSS基本结构*/
   font-size:20px;   /*设置文字字号*/
   color:red;       /*设置文字颜色*/
}
</style>
</head>

<body>
<h1>CSS</h1>
<p>顶过枯燥无味的学习!</p>
</body>
</html>


**CSS样式

①内联式:直接把CSS代码写在html标签里

<body>
<span style="color:blue">超酷的互联网</span></body>

②嵌入式:把CSS代码写在<style type="text/css"> </style>标签之间。

③外部式/外联式:把CSS代码写在一个单独文件里,html页面引用

<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>嵌入式css样式</title>
<link href="style.css" rel="stylesheet" type="text/css" />
</head>


优先级:就近原则,内联式>嵌入式>外联式


**选择器

1、标签选择器:html代码中的标签(如<html>、<body>、<h1>、<p>、<img>);

2、类选择器: .类选择器名称{css样式代码} ;

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>认识html标签</title>
<style type="text/css">
.stress{
    color:red;
}
</style>
</head>
<body>
    <p>标签外的字体为黑色<span class="stress">此处字体为红色</span>类选择器要加入圆点</p>

</body>
</html>

3、id选择器:与类选择器相同,只是定义的时候用 #选择器名称,调用的时候 id=选择器名称;

类选择器与Id选择器的相同点在于,可以使用于任何元素,不同点有①id选择器只能在文档中使用一次,而类选择器可以被使用多次;②id属性不能同时调用多个Id选择器,而类属性可以同时调用多个类选择器(两者用空格隔开)。

4、子选择器:用于指定标签元素的第一代子元素;

.food>li{border:1px solid red;}
/* 这行代码会使class名为food下的子元素li(水果、蔬菜)加入红色实线边框。*/


5、包含选择器:用于选择指定标签元素下的所有后辈元素;

.first  span{color:red;}

/*使某个标签范围里所有span元素都具备这个特性*/
/*子选择器(child selector)仅是指它的直接后代,而后代选择器是作用于所有子后代元素。后代选择器通过空格来进行选择*/

6、通用选择器:它使用一个(*)号指定,作用于html中所有标签元素;

7、伪选择器:给html不存在的标签(标签的某种状态)设置样式,如标签滑过字体变大;

a:hover{color:red; font-size:20px;}
/*其中一个能兼容所有浏览器的伪选择器:文字加入鼠标滑过字体颜色变为红色特效。 */


选择器分组的书写:

h1,span{color:red;}
/*它相当于下面两行代码*/
h1{color:red;}
span{color:red;}


**盒元素

块状元素:

1 ) html中<div>、 <p>、<h1>、<form>、<ul> 和 <li>就是块级元素

2)一个块级元素独占一行,每个块级元素都从新的一行开始,其后的元素也另起一行。

3 ) 元素的高度、宽度、行高以及顶和底边距都可设置。元素宽度在不设置的情况下,是它本身父容器的100%。

4 ) a{display:block;} 将内联元素a转换为块状元素,从而使a元素具有块状元素特点。 


内联元素:

1 )html中,<span>、<a>、<label>、 <strong> 和<em>就是典型的内联元素(行内元素)(inline)元素。

2 )  和其他内联元素在同一行上

3) 宽度,高度,顶部和底部边距不能自定义设置,元素的宽度就是它包含的文字或图片的宽度,

4) div{display:inline;} 块状元素可以转换成行内元素


内联块状元素:

1 ) html中,<img>、<input>就是内联块状(inline-block)元素。

2 ) 和其他元素都在同一行上

3 ) 高度,宽度和边距可以自定义设置

4 ) a{display: inline-block;}可以设置成内联块状元素


盒模型

是指装在这个盒子里面的一切元素,如文字、图片、电影等。

<div> <ul> <ol> <p> <h> <table>块级标签,都具备模型的特征

边框

盒子模型的边框就是围绕着内容及补白的线,具有边框样式(border-style)、颜色(border-color)和粗细(border-width)三个属性。

1、border-style(边框样式)常见样式有:

dashed(虚线)| dotted(点线)| solid(实线)。

2、border-color(边框颜色)中的颜色可设置为十六进制颜色,如:

border-color:#888;//前面的井号不要忘掉。

3、

border-width(边框宽度)中的宽度也可以设置为:

thin | medium | thick(但不是很常用),最常还是用象素(px)。

div{
    border:2px  solid  red;
}
上面是 border 代码的缩写形式,可以分开写:

div{
    border-width:2px;
    border-style:solid;
    border-color:red;
}
border-top 、border-bottom、border-left、border-right是单方向设置边框线。


边框的宽度和高度

css内定义的宽(width)和高(height),指的是填充以里的内容范围。

因此一个元素实际宽度(盒子的宽度)=左边界+左边框+左填充+内容宽度+右填充+右边框+右边界。




填充

填充是指元素与边框之间的距离,填充分为上、右、下与左。

div{padding:20px 10px 15px 30px;}
顺序一定不要搞混。可以分开写上面代码:

div{
   padding-top:20px;
   padding-right:10px;
   padding-bottom:15px;
   padding-left:30px;
}

如果上、右、下、左的填充都为10px;可以这么写
div{padding:10px;}

如果上下填充一样为10px,左右一样为20px,可以这么写:
div{padding:10px 20px;}

边界

边界是指元素与外界元素之间的距离,填充分为上、右、下与左。

div{margin:20px 10px 15px 30px;}
也可以分开写:
div{
   margin-top:20px;
   margin-right:10px;
   margin-bottom:15px;
   margin-left:30px;
}

如果上右下左的边界都为10px;可以这么写:
div{ margin:10px;}

如果上下边界一样为10px,左右一样为20px,可以这么写:
div{ margin:10px 20px;}

布局模型:

布局模型基于盒模型之上,分为Flow(流动模型)、Layer(层模型) 和 Float(浮动模型)。


流动模型:

1 ) 流动(Flow)是默认的网页布局模式;

2 ) 块状元素都会在所处的包含元素内自上而下按顺序垂直延伸分布,在默认状态下,块状元素的宽度都为100%;

3 ) 内联元素都会在所处的包含元素内从左到右水平分布显示。


浮动模型(Flow):

块状元素这么霸道都是独占一行,如果现在我们想让两个块状元素并排显示,怎么办呢?

任何元素在默认情况下是不能浮动的,但可以用 CSS 定义为浮动,如 div、p、table、img 等元素都可以被定义为浮动。如下代码可以实现两个 div 元素一行显示。两个div边框靠左并排对齐。

div{
    width:200px;
    height:200px;
    border:2px red solid;
    float:left;
}
<div id="div1"></div>
<div id="div2"></div>






层模型:

分为绝对定位(position:absolute)、相对定位(position:related)、固定定位(position:fixed)



**样式

① 继承性

CSS的某些样式是具有继承性的。

继承是一种规则,它允许样式不仅应用于某个特定html标签元素,而且应用于其后代。例如color元素具有继承性,但如p{boder 1px  solid  red;}红色边框的样式就不具有继承性。

<!--
如某种颜色应用于p标签,这个颜色设置不仅应用p标签,还应用于p标签中的所有子元素文本,这里子元素为span标签。
下列中,<span>标签中也是红色字体。
-->
<head>
<style type="text/css">
p{color:red;}
</style>
</head>
<body>
<p>三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p>
</body>

②特殊性

浏览器是根据权值来判断使用哪种css样式的,权值高的就使用哪种css样式。标签的权值为1,类选择符的权值为10,ID选择符的权值最高为100,继承的权值很低,相当于0.1。例如下列代码:

p{color:red;} /*权值为1*/
p span{color:green;} /*权值为1+1=2*/
.warning{color:white;} /*权值为10*/
p span.warning{color:purple;} /*权值为1+1+10=12*/
#footer .note p{color:yellow;} /*权值为100+10+1=111*/
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>特殊性</title>
<style type="text/css">
p{color:red;}
.first{color:green;}/*因为权值高显示为绿色*/
span{color:pink;}/*设置为粉色*/
p>span{color:blue;}

</style>
</head>
<body>
    <h1>勇气</h1>
    <p class="first">三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p></body>
<p>标签内的字体为绿色,<span>标签内的字体为蓝色。


③层叠

css样式具有相同权重值,最近原则

p{color:red;}
p{color:green;}
<p class="first">三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p>
<!-- 显示为绿色-->

p{color:red!important;}
p{color:green;}
<p class="first">三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p>

<!-- 字段显示为红色,"!important"设置高权值。
样式优先级为:浏览器默认的样式 < 网页制作者样式 < 用户自己设置的样式,但记住!important优先级样式是个例外,权值高于用户自己设置的样式。
-->
















评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值