css简介_动力节点Java学院整理

所属分类: 网页制作 / CSS 阅读数: 965
收藏 0 赞 0 分享

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.尽量少使用复杂层级关系。

更多精彩内容其他人还在看

动态的样式语言less语法详解之变量与extend

本质上,LESS 包含一套自定义的语法及一个解析器,用户根据这些语法定义自己的样式规则,这些规则最终会通过解析器,编译生成对应的 CSS 文件。LESS 并没有裁剪 CSS 原有的特性,更不是用来取代 CSS 的,而是在现有 CSS 语法的基础上,为 CSS 加入程序式语言的特性
收藏 0 赞 0 分享

动态的样式语言less语法详解之混合属性

这篇文章主要介绍了动态的样式语言less语法详解之混合属性,需要的朋友可以参考下
收藏 0 赞 0 分享

浏览器端如何使用Less

这篇文章主要介绍了浏览器端如何使用Less,需要的朋友可以参考下
收藏 0 赞 0 分享

CSS3动画效果回调处理详解

这篇文章主要详细介绍了CSS3动画效果回调处理,需要的朋友可以参考下
收藏 0 赞 0 分享

纯css3实现的竖形无限级导航

本文给大家介绍了一款非常漂亮的纯CSS3打造的竖形无限级导航特效,小伙伴们需要的话直接拿走使用吧
收藏 0 赞 0 分享

一款纯css3实现的tab选项卡的实列教程

css3怎么做tab选项卡?下面费大家分享一款纯css3实现的tab选项卡的实列教程,单击左侧的选项的时候,右侧内容以动画的形式展示。下文有具体代码,想学的朋友可以进来参考一下
收藏 0 赞 0 分享

一款利用纯css3实现的win8加载动画的实例分析

之前已经和大家分享了很多css3动画的实例教程,今天给大家分享一款纯css3实现的win8加载动画。在这款实例中动画效果完全由css3实现,需要的朋友可以参考下
收藏 0 赞 0 分享

一款纯css3实现的竖形二级导航的实例教程

这篇文章主要为大家介绍了一款纯css3实现的竖形二级导航的实例教程,这款导航菜单特色是可以是无限级。下面有代码,不会的朋友可以过来借鉴学习哦
收藏 0 赞 0 分享

padding ie 不兼容问题

这篇文章主要介绍了padding ie 不兼容问题,需要的朋友可以参考下
收藏 0 赞 0 分享

CSS3简单实现照片墙

本文给大家推荐的是使用CSS3简单实现照片墙效果的代码,非常简单,也很实用,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多