原本我们通过对HTML元素加一些附加属性进行改变页面的外观,比如width、height、bg-color、padding、spacing等属性。
现在有了CSS能够把页面布局和页面外观完全分离开来。只需要把css链接到文本里就可以实现改变外观。
css相对于传统的方法最明显的优势:如果你想要把所有的h1元素全部设置成统一的样式,传统的方法需要一个一个设置,而css则只需要一个设置即可。
CSS的形式如下:
元素或类{ 特性:值; 特性:值; ............ } 比如: 对于元素: body{ background-color:white; } 对于类: td.code{ font-size:10px; } 这是对于td这个元素中class值为code的元素进行描述。 |
外部链接css的方式:
内部css的使用方式:
css代码; |
外部的CSS的好处:
(1)重用。
(2)修改同步更新,不需要一个一个修改。
(3)设置不同的输出设备。
@import "1.css";
(1)一般选择器:直接用元素。比如直接h1;
(2)通用选择器:适用于全部的元素。*{...}
(3)类选择器:指定特定的class。
- h1.classname:这种适用于h1元素中class属性的值为classname的元素。
- .classname:这种适用于任何元素中class属性的值是classname的元素。
(4)子选择器:选择某种依赖关系的元素。比如td>b,表示td元素的直接子元素b的元素。
(5)后继选择器:某种依赖关系的元素。比如 table b,表示table中的b元素。
1.字体类别:
(1)font-family:这是字体,比如serif,monospace等。
具体用法:font-family : arial,sans-serif;表示首选arial字体,如果机器中没有arial字体,则选用sans-serif字体。
(2)font-size:大小。
具体用法:font-size:12px;表示字体大小为12像素.
(3)font-weight:表示是否为粗体。
具体用法:font-weight:bold;表示为粗体。
(4)font-style:表示是否是斜体。
具体用法:font-style:italic;表示为斜体。
2.文本类别:
(1)text-align:表示文本的位置。可选为left,right,center;
具体用法:text-align:center;表示文本在中央。
(2)text-decoration:表示文本是否要下划线、删除线等。可选为underline\line-through;
具体用法:text-decoration:underline;表示文本下方有下划线。
(3)color:表示文本的颜色。
具体用法:color:red;表示颜色是红色。
(4)text-indent:文本缩进多少。
具体用法:text-indent:2px;表示缩进2个像素。
(5)line-height:表示行之间的宽度。
具体用法:line-height:2px;表示行之间间隔2像素。
补充:文本伪类:
(1)first-letter:对于第一个字母特别着重。
形如:open;
具体用法:p:first-letter{....}
(2)first-line:对于第一行特别着重。
形如:I am
xiazdong;
具体用法:p:first-line{...}
3.背景类别:
(1)background-color:
line-height:2px 表示行间距.
padding:
border-style:边框的形状,比如solid表示实线。
border-color:边框的颜色。
border-width:边框的宽度。
4.边框类别:可用于任何元素的边框。
(1)border-width:表示边框的宽度。
具体用法:border-width:2px;表示边框的宽度为2px。
(2)border-style:表示边框的类型。可选:solid,dotted
具体用法:border-style:solid;表示边框是实线。
(3)border-color:表示边框的颜色。
具体用法:border-color:red;表示边框的颜色为红色。
(4)padding:表示边框和文本的距离。
具体用法:padding:2px;表示边框和文本距离为2像素。
(5)margin:表示边框的距离。
具体用法:margin:2px;表示边框之间距离为2像素。
大小类别:
(6)width:框的宽度。
(7)height:框的高度。
(8)max-height和min-height:框的最大高度和最小高度。
(9)max-width和min-width:框的最大宽度和最小宽度。
(10)overflow:表示框是否要滚动条。
具体用法:overflow:scroll;表示边框需要滚动条。
5.背景类别:
(1)background-color:表示背景颜色。
具体用法:background:blue;
(2)background-image:表示背景的图片。
具体用法:background-image:url("apple.jpg");表示背景来自apple.jpg文件。
(3)background-position:表示背景图片的位置。可选:(1)20%,30%(2)left(3)center....
具体用法:background-position:center;表示图片在中心。
(4)background-attachment:表示图片是否会随着滚动条移动而变化。可选:fixed,scroll
具体用法:background-attachment:fixed;表示图片不会变化。
(5)background-repeat:表示图片是否会重复。可选:no-repeat,repeat,repeat-x,repeat-y;
具体用法:background-repeat:no-repeat;表示不会重复。
常用颜色:
(1)#cccccc:深灰色。
(2)#efefef:浅灰色。
(2)#ffffff:白色。
(3)#000000:黑色。
6.列表类别:
(1)list-style-type:表示前标的样式。可选:disc(默认),circle,square,none,decimal,lower-roman;
具体用法:list-style-type:square;表示用方块进行标号。
(2)list-style-position:表示标号的位置。可选:inside,outside;
具体用法:list-style-position:outside;
7.表类别:
(1)border-collapse:是否应该显示每一个边框;可选:collapse或separate;
具体用法:border-collapse:separate;表示每个边框都会显示,不会合并。
(2)border-spacing:边框之间的距离;
具体用法:border-spacing:15px;表示边框之间距离为15像素。
8.外边框类别:和边框的区别是不占用空间。
(1)outline-style:
(2)outline-color:
(3)outline-width:
9.:before和:after伪元素:
(1):before:用于指定在哪些元素之前加哪些内容。
具体用法:h1:before{content:"这里是h1内容:";}这样在h1的前面会加上这个字符串。
(2):after和:before正好相反。
**计数器函数counter():
这个计数器是能够遇到某种情况自动让数字递增。
比如:
body{ counter-reset:chapter; } h1:before{ content:counter(chapter); } h1{ counter-increment:chapter; } 这个例子表明,当进入body时,先清零计数器chapter,在h1之前添加计数器,每次遇到h1,计数器就加一。 |
10.链接类别:
伪类:能够使得链接在不同状态下的样式不同。
(1)link:当一般状态下。
(2)visited:访问完后。
(3)active:当激活链接时。
(4)hover:当停留在链接上时。
具体用法:
a:link{ color:red; } a:hover{ color:blue; } a:visited{ color:black; } 链接一般状态为红色,鼠标停留在链接上时是蓝色,访问完后是黑色。 |
11.其他类别:
(1)display:用于将内联框显示为外部框或反过来。
具体用法:display:block;
(2)cursor:用于指定鼠标指针的样式。
(3)visibility:某个元素是否显示。
布局:
position特性,有static(默认),relative,absolute,fixed;可选。
如果选了后面三个,则可以附加left,top,right,bottom进行移位,但是有一个规则,如果left:30px;则表明向右移,top:30px;表明向下移。
1.普通定位:没有特殊的,平时的按html代码顺序布局。
2.相对定位(relative):相对于普通定位进行偏移,但是这个相对定位的元素没有剥离出普通定位,即如果有三个段落,如果第二个段落移开了,但是空间还是依然保留,不会被第三个段落占用。
具体用法:
position:relative; top:30px; left:30px; |
注意:如果想要让一个段落遮掉另一个段落,则需要设置background-color;
3.绝对定位(absolute):被排除在普通定位之外,其他类似相对定位。如果有三个段落,如果第二个段落移开了,则空间被第三个段落占用。
具体用法:
position:absolute; top:30px; left:30px; |
4.固定定位(fixed):完全脱离普通定位,而是固定在窗体的某一个位置,不论滚动条移动也不会变化。
注意:z-index特性可以设置多个元素重叠时,元素的叠放次序,z-index越大,则越靠顶。
具体用法:
position:fixed; top:0px; left:0px; 表明这个框不动,并且在最顶部。 |
5.浮动定位float:脱离普通定位,并且包含在框中,但不会重叠。指定float后,需要指定width特性,为了确定框的宽度。
具体用法:
float:left; width:100px; 表明某个元素放在左边,并且宽度为100像素。 |