动力节点java之css简介

动力节点java之css简介

CSS(Cascade Style Sheet),即层级样式表。

HTML可以说只是给网页填充了内容,CSS则是对网页进行化妆、修饰,比如给文字设置字体、颜色、大小等。

以前在HTML标签中能够通过设置属性的方式(比如<div width="80px">)为标签定义样式(类似CSS的功能),但是现在推荐使用CSS设置(div{width:80px;}),即"HTML与CSS分离",在web中还有“页面展示与逻辑处理分离”等概念。

一般来说目前实现网页时不需要从零做起,网上有很多好的CSS代码可以使用但是为了能看懂那些代码(或更好地学习CSS框架),我们需要学习CSS的基本知识。

CSS的基本结构如下:

<selector>{
<attr1>:<value1>;
<attr2>:<value2>;
<attr3>:<value3>;
......
<attrN>:<valueN>;
}

解释:

<selector>的中文名叫“选择器”,表示对哪个元素设置样式。<selector>大括号内部设置具体的样式,如字体等。

设置样式的方法是通过多对<attr>:<value>组合而成,中间用分号( ; )分隔。

这里举个简单的例子:

body{ //对<body>内的元素进行设置
font-size:12px;           //设置字体大小为12px,px是pixel的缩写,表示像素
font-family:sans-serif,Georgia; //设置首选字体为sans-serif,如果本机内没安装此字体,则使用Georgia
}

CSS的规则

1.继承原则:如果父标签定义了某样式,则默认对应的子标签也应用该样式。

2.就近原则:离修饰标签越近的CSS样式优先级越高。

引入CSS样式的方法

这里只介绍两种最常用的:

1.内部样式表:在<head></head>内部添加:<style type="text/css">......</style>

2.外部样式表:将CSS放在文件(如home.css)中,并在<head></head>内部添加:<link rel="stylesheet" type="text/css" href="home.css"/>

在CSS中不可避免会遇到颜色设置,因此这里我们需要学习怎么表示颜色。

共有4种颜色表示法:

1.预定义颜色:例如“color:black”中的black就是预定义的颜色。

2.十六进制表示法:#ABCDEF,其中AB、CD、EF分别对应R、G、B。例子:#FFFFFF 表示白色。

3.短十六进制表示法:这是对第二种表示法的特例,当A=B时A和B只写一个(同样地,C=D、E=F 时也类似)。例子:#FF00CC 可简写为 #F0C.

4.rgb表示法:rgb(255,255,255) 表示白色。

CSS Reset

起因:在不同浏览器中的默认CSS样式可能是不同的,比如按钮,在IE中可能是样式A,在Chrome中是样式B,在Firefox中是样式C,这种不一致性会让开发者不爽。因此就需要CSS Reset来统一不同浏览器的默认样式。

CSS reset 通俗地说就是“一段CSS代码,这段代码能够初始化基本的标签,使得在不同浏览器中,各标签的显示样式是一样的。”

还有一个更加应用广泛的替代CSS Reset的代码:Normalize.css,他被很多框架使用。

最常用的CSS Reset代码是 Eric Meyer 写的“CSS Reset 2.0”,代码如下:

 /**
 * Eric Meyer's Reset CSS v2.0 (http://meyerweb.com/eric/tools/css/reset/)
 * http://cssreset.com
 */
 html, body, div, span, applet, object, iframe,
 h1, h2, h3, h4, h5, h6, p, blockquote, pre,
 a, abbr, acronym, address, big, cite, code,
 del, dfn, em, img, ins, kbd, q, s, samp,
 small, strike, strong, sub, sup, tt, var,
 b, u, i, center,
 dl, dt, dd, ol, ul, li,
 fieldset, form, label, legend,
 table, caption, tbody, tfoot, thead, tr, th, td,
 article, aside, canvas, details, embed, 
 figure, figcaption, footer, header, hgroup, 
 menu, nav, output, ruby, section, summary,
 time, mark, audio, video {
  margin: 0;
   padding: 0;
  border: 0;
  font-size: 100%;
   font: inherit;
   vertical-align: baseline;
 }
 /* HTML5 display-role reset for older browsers */
 article, aside, details, figcaption, figure, 
 footer, header, hgroup, menu, nav, section {
   display: block;
 }
 body {
   line-height: 1;
 }
 ol, ul {
   list-style: none;
 }
 blockquote, q {
   quotes: none;
 }
 blockquote:before, blockquote:after,
 q:before, q:after {
   content: '';
   content: none;
 }
 table {
   border-collapse: collapse;
   border-spacing: 0;
 }

*:选择任何元素。格式为:*{...}

标签选择器:选择指定标签。格式为:<tag>{...}

id选择器:选择指定 id 的元素。某个 id 在一个页面中是唯一的。格式为:#<id>{...}

class选择器:选择指定class的元素。格式为:.<class>{...}。值得一提的是,class选择器的变型:

与标签选择器一起使用,格式为:<tag>.<class>。表示只选择具有class=<class>的<tag>标签。

多个class一起使用,格式为:.<class1>.<class2>。表示class同时属于<class1>和<class2>的元素。

后代选择器:选择指定元素的指定后代元素(后代和子元素是不同的,并不一定要紧跟在父元素里面)。格式为:<father> <空格><descendent> ,例如 div h3 解释为“div元素的所有<h3>标签”。

子元素选择器:选择指定元素的子元素(子元素指的是孩子,并不包含孙子...)。格式为:<father> > <child>。

属性选择器:选择具有指定属性或指定属性具有特定值的元素。格式为:<selector>[<attribute1>][<attribute2>]或<selector>[<attribute1>="<value1>"][<attribute2>="<value2>"]。

部分匹配属性值:<selector>[<attribute>*="<value>"]表示只要<attribute>属性中包含<value>值即可。

相邻兄弟选择器:选择(紧挨着的)相邻的兄弟的元素。格式为:<selector1> + <selector2>。表示选择紧跟在selector1后面的selector2。

伪类选择器:

<selector>:first-child{...} . 当<selector>为某个元素的第一个子元素时应用样式。

<selector>:focus{...} . 当<selector>拥有键盘输入焦点时应用样式。

a:link{...} . 当<a>未被访问过时应用样式。

a:visited{...}. 当<a>已被访问时应用样式。

a:hover{...} . 当鼠标悬浮在<a>上时应用样式。(随着移动设备的越来越流行,我们发现移动设备是没有鼠标的,因此没有hover这个概念,hover变得不那么重要了。)

a:active{...}. 当<a>被激活(激活指的是鼠标按下且未松开的这段时间)时应用样式。

注意:在css中一定要以:link -> visited -> hover -> active 的顺序进行声明!!!!

伪元素选择器:

<selector>:first-line{...}. 选择<selector>的第一行。注意:<selector>必须是块级元素。

<selector>:first-letter{...}. 选择<selector>的第一个字母。注意:<selector>必须是块级元素。

<selector>:before{content:"..."}. 在<selector>的前面插入内容。例如:h1:before{content:url(1.jpg)}表示在<h1>前面插入一张图片。

<selector>:after{content:"..."}. 在<selector>的后面插入内容。

选择器分组:多个选择器可以用逗号(,)隔开,表示同时对多个选择器设置样式。格式为:<selector1>,<selector2>,<selector3>{...}

应用:

1.选择一个有序列表中的第三行:ol > li:first-child + li + li

2.选择class="c1"的div:div.c1

选择器定义准则:

1.最常用的选择器:id选择器、class选择器。

2.尽量少使用复杂层级关系。