CSS指层叠样式表(Cascading Style Sheets),CSS 是标准的布局语言,用来控制元素的尺寸、颜色、排版。CSS 由 W3C 发明,用来取代基于表格的布局、框架以及其他非标准的表现方法。样式 (style) 定义如何显示 HTML 元素;样式通常存储于样式表中;外部样式表存储于 CSS 文件中。

  CSS可以解决html代码对样式定义的重复,提高了后期样式代码的可维护性,并增强了网页的显示效果功能。简单一句话:CSS将网页内容和显示样式进行分离,提高了显示功能。

1、CSS基础部分

层叠次序

  当同一个HTML元素被不止一个样式所定义时,会使用哪个样式呢?一般而言,所有的样式会根据下面的规则层叠于一个新的虚拟样式表中,其中数字 4 拥有最高的优先权。

  1. 浏览器缺省设置
  2. 外部样式表
  3. 内部样式表(位于 <head> 标签内部)
  4. 内联样式(在 HTML 元素内部)

CSS基本语法

  CSS 规则由两个主要的部分构成:选择器,以及一条或多条声明。 selector {declaration1; declaration2; ... declarationN }
  选择器通常是您需要改变样式的 HTML 元素。每条声明由一个属性和一个值组成。属性(property)是您希望设置的样式属性(style attribute)。每个属性有一个值。属性和值被冒号分开。selector {property: value}

  CSS 对大小写不敏感。不过存在一个例外:如果涉及到与 HTML 文档一起工作的话,class 和 id 名称对大小写是敏感的。

CSS高级语法

  选择器的分组,你可以对选择器进行分组,这样,被分组的选择器就可以分享相同的声明。用逗号将需要分组的选择器分开。在下面的例子中,我们对所有的标题元素进行了分组。所有的标题元素都是绿色的。

  1. 1 h1,h2,h3,h4,h5,h6 {
  2. 2 color: green;
  3. 3 }

CSS派生选择器
  通过依据元素在其位置的上下文关系来定义样式,你可以使标记更加简洁。在 CSS1 中,通过这种方式来应用规则的选择器被称为上下文选择器 (contextual selectors),这是由于它们依赖于上下文关系来应用或者避免某项规则。在 CSS2 中,它们称为派生选择器,但是无论你如何称呼它们,它们的作用都是相同的。
  派生选择器允许你根据文档的上下文关系来确定某个标签的样式。通过合理地使用派生选择器,我们可以使 HTML 代码变得更加整洁。比方说,你希望列表中的 strong 元素变为斜体字,而不是通常的粗体字,可以这样定义一个派生选择器,它只对li标签中的strong标签起作用:

  1. 1 li strong {
  2. 2 font-style: italic;
  3. 3 font-weight: normal;
  4. 4 }

CSS id 选择器
  id 选择器可以为标有特定 id 的 HTML 元素指定特定的样式。id 选择器以 "#" 来定义。下面的两个 id 选择器,第一个可以定义元素的颜色为红色,第二个定义元素的颜色为绿色:

  1. 1 #red {color:red;}
  2. 2 #green {color:green;}

下面的 HTML 代码中,id 属性为 red 的 p 元素显示为红色,而 id 属性为 green 的 p 元素显示为绿色。注意:id 属性只能在每个 HTML 文档中出现一次。

  1. 1 <p id="red">这个段落是红色。</p>
  2. 2 <p id="green">这个段落是绿色。</p>

id 选择器和派生选择器
  在现代布局中,id 选择器常常用于建立派生选择器。

  1. #sidebar p {
  2. font-style: italic;
  3. text-align: right;
  4. margin-top: 0.5em;
  5. }

一个选择器,多种用法

  即使被标注为 sidebar 的元素只能在文档中出现一次,这个 id 选择器作为派生选择器也可以被使用很多次:

  1. // haha为form的id
  2. #haha {
  3. color : green;
  4. }
  5. #haha input {
  6. color : blue;
  7. }
  8. #haha select {
  9. color : red;
  10. }

  上面的样式只会应用于id是haha元素内的内容。比如,id为haha的form内input标签中字体颜色为blue,select标签中字体颜色为red,其他的颜色为green。

CSS类选择器

  在 CSS 中,类选择器以一个点号显示: .center {text-align: center}
  在上面的例子中,所有拥有 center 类的 HTML 元素均为居中。在下面的 HTML 代码中,h1 和 p 元素都有 center 类。这意味着两者都将遵守 ".center" 选择器中的规则。

  1. 1 <h1 class="center">
  2. 2 This heading will be center-aligned
  3. 3 </h1>
  4. 4
  5. 5 <p class="center">
  6. 6 This paragraph will also be center-aligned.
  7. 7 </p>

  注意:类名的第一个字符不能使用数字!它无法在 Mozilla 或 Firefox 中起作用。

  我们在使用时是使用类选择器还是ID选择器呢?注意,ID选择器会使用一次,并且仅一次,如果有多个ID项匹配ID选择器,则只有第一个起作用。不同于类选择器,ID 选择器不能结合使用,因为 ID 属性不允许有以空格分隔的词列表。类似于类,可以独立于元素来选择 ID。有些情况下,您知道文档中会出现某个特定 ID 值,但是并不知道它会出现在哪个元素上,所以您想声明独立的 ID 选择器。例如,您可能知道在一个给定的文档中会有一个 ID 值为 mostImportant 的元素。您不知道这个最重要的东西是一个段落、一个短语、一个列表项还是一个小节标题。您只知道每个文档都会有这么一个最重要的内容,它可能在任何元素中,而且只能出现一个。在这种情况下,特别适合使用ID选择器。

CSS属性选择器

  对带有指定属性的 HTML 元素设置样式。可以为拥有指定属性的 HTML 元素设置样式,而不仅限于 class 和 id 属性。属性选择器在为不带有 class 或 id 的表单设置样式时特别有用:

  1. [attribute] {
  2. color : red;
  3. }

  以上代码就会对<p attribute="">我是一个段落</p>产生作用了。

CSS的创建

  如何插入样式表,当读到一个样式表时,浏览器会根据它来格式化 HTML 文档。插入样式表的方法有三种:外部样式表、内部样式表和内敛样式。

外部样式表

  当样式需要应用于很多页面时,外部样式表将是理想的选择。在使用外部样式表的情况下,你可以通过改变一个文件来改变整个站点的外观。每个页面使用 <link> 标签链接到样式表。<link> 标签在(文档的)头部:

  1. 1 <head>
  2. 2 <link rel="stylesheet" type="text/css" href="mystyle.css" />
  3. 3 </head>

  浏览器会从文件 mystyle.css 中读到样式声明,并根据它来格式文档。外部样式表可以在任何文本编辑器中进行编辑。文件不能包含任何的 html 标签。样式表应该以 .css 扩展名进行保存。下面是一个样式表文件的例子:

  1. 1 hr {color: sienna;}
  2. 2 p {margin-left: 20px;}
  3. 3 body {background-image: url("images/back40.gif");}

内部样式表

  当单个文档需要特殊的样式时,就应该使用内部样式表。你可以使用 <style> 标签在文档头部定义内部样式表,就像这样:

  1. <head>
  2. <style type="text/css">
  3. hr {color: sienna;}
  4. p {margin-left: 20px;}
  5. body {background-image: url("images/back40.gif");}
  6. </style>
  7. </head>

内联样式
  由于要将表现和内容混杂在一起,内联样式会损失掉样式表的许多优势。请慎用这种方法,例如当样式仅需要在一个元素上应用一次时。要使用内联样式,你需要在相关的标签内使用样式(style)属性。Style 属性可以包含任何 CSS 属性。本例展示如何改变段落的颜色和左外边距:

  1. 1 <p style="color: sienna; margin-left: 20px">
  2. 2 This is a paragraph
  3. 3 </p>

HTML+CSS程序示例

  1. <html>
  2. <head>
  3. <title>HTML和CSS学习</title>
  4.  
  5. <!-- 引用外部文件方式
  6. <link type="text/css" rel="stylesheet" href="body.css"/>
  7. -->
  8.  
  9. <!-- 直接在head中写css方式 -->
  10. <style type="text/css">
  11.  
  12. /* id选择器 */
  13. #haha {
  14. color : green;
  15. }
  16. #haha input {
  17. color : blue;
  18. }
  19. #haha select {
  20. color : red;
  21. }
  22.  
  23. /* 属性选择器 */
  24. [attribute] {
  25. color : brown;
  26. }
  27.  
  28. /* 类选择器 */
  29. .p_class {
  30. color : red;
  31. }
  32.  
  33. /* 属性选择器,只对input中type为text产生作用 */
  34. input[type="text"] {
  35. background-color:yellow;
  36. }
  37. </style>
  38.  
  39. </head>
  40. <body>
  41.  
  42. <p>我是一个段落</p>
  43. <p attribute="">我是一个段落</p> <!-- 属性选择器 -->
  44. <p class="p_class">我是一个段落</p> <!-- 类选择器 -->
  45.  
  46. <hr color="blue"/>
  47. <!-- id选择器 -->
  48. <form id="haha" action="/example/html/form_action.asp" method="post">
  49. 用户名: <input type="text" name="username"/> <br/>
  50. 密&nbsp;码: <input type="password" name="password"/> <br/>
  51. 上&nbsp;传: <input type="file" name="upload_file"/> <br/>
  52. 图&nbsp;片: <input type="image" src="pic.jpg" width="40px" height="20px"/> <br/>
  53. 单&nbsp;选: <input type="radio" name="sex" checked="checked" value="man"/><input type="radio" name="sex" value="women"/><br/>
  54. 多&nbsp;选: <input type="checkbox" name="sex2" checked="checked" value="man"/><input type="checkbox" name="sex2" value="women"/><br/>
  55. 城&nbsp;市: <select name="city">
  56. <option value="null">--请选择--</option>
  57. <option value="beijing">北京</option>
  58. <option value="shanghai">上海</option>
  59. <option value="hangzhou">杭州</option>
  60. </select> <br/>
  61. 留言板: <textarea>
  62. </textarea> <br/>
  63. <input type="submit" value="提交" /> <input type="reset" />
  64. </form>
  65. <hr color="red"/>
  66.  
  67. <form>
  68. 用户名: <input type="text" name="username" value="123"/> <br/>
  69. 密&nbsp;码: <input type="password" name="password"/> <br/>
  70. </form>
  71.  
  72. </body>
  73. </html>

网页端显示效果如下:

2、CSS样式

CSS背景

  CSS 允许应用纯色作为背景,也允许使用背景图像创建相当复杂的效果。CSS 在这方面的能力远远在 HTML 之上。

  1. p.bg {
  2. background-image: url(img/bg_1.jpg);
  3. padding: 20px;
  4. background-repeat: repeat-y;
  5. background-position: center;
  6. text-align: center;
  7. }
  8. <p class="bg">我是一个有背景的段落</p>

最后网页效果为:

CSS文本

  CSS 文本属性可定义文本的外观。通过文本属性,您可以改变文本的颜色、字符间距,对齐文本,装饰文本,对文本进行缩进,等等。

  1. 1 {
  2. 2 text-indent: 2em; /* 缩进2个字符 */
  3. 3 text-align: left; /* 左对齐 */
  4. 4 word-spacing: 20px; /* 字符间隔 */
  5. 5 letter-spacing: 5px; /* 字母间隔 */
  6. 6 text-transform: uppercase; /* 文本转换为大写字符 */
  7. 7 text-decoration: underline; /* 文本下划线处理 */
  8. 8 }

CSS字体

  1. {
  2. font-family: serif; /* 选择字体 */
  3. font-style: normal; /* 文本格式 粗体/斜体 */
  4. font-size: 20px; /* 文本大小 */
  5. }

CSS链接

  1. a:link { color: blue; } /* 未被访问的链接 */
  2. a:visited { color: red; } /* 已被访问的链接 */
  3. a:hover { color: yellow; } /* 鼠标指针移动到链接上 */
  4. a:active { color: black; } /* 正在被点击的链接 */

CSS列表

  1. ul.disc {list-style-type: disc}
  2. ul.circle {list-style-type: circle}
  3. ul.square {list-style-type: square}
  4. ul.none {list-style-type: none}

CSS表格

  1. table, th, td {
  2. border: 1px solid blue; /* 边框设置蓝色表框 */
  3. border-collapse: collapse; /* 是否将表格边框折叠为单一边框 */
  4. }
  5. table {
  6. width: 100%; /* 表格宽度 */
  7. height: 100%;
  8. }

CSS轮廓

  轮廓(outline)是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用。CSS outline 属性规定元素轮廓的样式、颜色和宽度。

  1. {
  2. outline: dashed;
  3. outline-color: red;
  4. outline-style:dotted;
  5. }

3、CSS框模型

  CSS 框模型 (Box Model) 规定了元素框处理元素内容、内边距、边框 和 外边距 的方式。

元素框的最内部分是实际的内容,直接包围内容的是内边距。内边距呈现了元素的背景。内边距的边缘是边框。边框以外是外边距,外边距默认是透明的,因此不会遮挡其后的任何元素。

CSS内边距

  1. h1 {
  2. padding: 10px; /* 所有 h1 元素的各边都有 10 像素的内边距 */
  3. }
  4. h1 {
  5. padding: 10px 0.25em 2ex 20%; /* 按照上、右、下、左的顺序分别设置各边的内边距,具有不同单位*/
  6. }
  7. h1 {
  8. padding-top: 10px; /* 上下左右分别设置 */
  9. padding-right: 0.25em;
  10. padding-bottom: 2ex;
  11. padding-left: 20%;
  12. }

CSS边框

  元素的边框 (border) 是围绕元素内容和内边距的一条或多条线。CSS border 属性允许你规定元素边框的样式、宽度和颜色。

  1. h1 {
  2. border-style: outset; /* 设置边框样式(凸起按钮效果) */
  3. border-width: 10px; /* 边框宽度 */
  4. border-color: red; /* 边框颜色 */
  5. }

CSS外边框

  1. h1 {
  2. margin: 10px; /* 四边外边距属性 */
  3. margin: 20px 30px 30px 20px; /* 四边外边距属性 */
  4. margin-top: 20px; /* 单边外边距属性 */
  5. margin-right: 30px;
  6. margin-bottom: 30px;
  7. margin-left: 20px;
  8. }

4、CSS定位

  CSS 有三种基本的定位机制:普通流、浮动和绝对定位。除非专门指定,否则所有框都在普通流中定位。也就是说,普通流中的元素的位置由元素在 (X)HTML 中的位置决定。块级框从上到下一个接一个地排列,框之间的垂直距离是由框的垂直外边距计算出来。行内框在一行中水平布置。可以使用水平内边距、边框和外边距调整它们的间距。但是,垂直内边距、边框和外边距不影响行内框的高度。由一行形成的水平框称为行框(Line Box),行框的高度总是足以容纳它包含的所有行内框。不过,设置行高可以增加这个框的高度。

CSS相对定位

  相对定位是一个非常容易掌握的概念。如果对一个元素进行相对定位,它将出现在它所在的位置上。然后,可以通过设置垂直或水平位置,让这个元素“相对于”它的起点进行移动。如果将 top 设置为 20px,那么框将在原位置顶部下面 20 像素的地方。如果 left 设置为 30 像素,那么会在元素左边创建 30 像素的空间,也就是将元素向右移动。

  1. #box_relative {
  2. position: relative;
  3. left: 30px;
  4. top: 20px;
  5. }

CSS绝对定位

  绝对定位使元素的位置与文档流无关,因此不占据空间。这一点与相对定位不同,相对定位实际上被看作普通流定位模型的一部分,因为元素的位置相对于它在普通流中的位置。普通流中其它元素的布局就像绝对定位的元素不存在一样:

  1. #box_relative {
  2. position: absolute;
  3. left: 30px;
  4. top: 20px;
  5. }

5、CSS高级特性

CSS水平排列

  1. .line
  2. {
  3. display: inline; /* 当块级元素类为line时,这些块就会水平排列显示 */
  4. }

CSS尺寸

  1. img.normal {
  2. height: normal; /* 设置图片正常显示 */
  3. }
  4. img.small {
  5. height: 100px; /* 图片小图显示 */
  6. }

CSS导航条

  1. /* 导航条格式 */
  2. .navigation {
  3. margin: 0;
  4. padding: 0;
  5. }
  6. .navigation li {
  7. display: inline;
  8. }
  9. <p>以下是导航条内容</p>
  10. <ul class="navigation">
  11. <li><a href="#">计算机</a></li>
  12. <li><a href="#">经济</a></li>
  13. <li><a href="#">历史</a></li>
  14. </ul>

  网页显示效果如下:

参考

  1、CSS 教程

  2、Web学习之html

Web学习之css的更多相关文章

  1. Web学习之CSS总结

    银角大王武Sir的博客地址 1.positoin属性固定元素的定位类型 说明:这个属性定义建立元素布局所用的定位机制.任何元素都可以定位,不过绝对或固定元素会生成一个块级框,而无论该元素是什么类型.相 ...

  2. web中的CSS、Xpath等路径定位方法学习

    今天不到八点就到公司了,来的比较早,趁着有点时间,总结下web中的CSS.Xpath等路径定位定位的方式吧! 简单的介绍下xpath和css的定位 理论知识就不罗列了 还是利用博客园的首页.直接附上代 ...

  3. Java Web 学习路线

    实际上,如果时间安排合理的话,大概需要六个月左右,有些基础好,自学能力强的朋友,甚至在四个月左右就开始找工作了.大三的时候,我萌生了放弃本专业的念头,断断续续学 Java Web 累计一年半左右,总算 ...

  4. Java web 学习之旅

    java web学习之旅 来公司十天了,感觉已经慢慢地融入了这个环境中,几个学长人都很好,都是在他们帮助下,我才能比较顺利的开始了学习java web的旅途. 来这里学习的第一个阶段是做一个简单的用户 ...

  5. 如何从零开始学习DIV+CSS

    CSS是样式,DIV是层.DIV+CSS是网站标准(web标准),通常为了说明与HTML网页设计语言中的表格(table)定位方式的区别.因为XHTML网站设计标准中,不再使用表格定位技术,而是采用D ...

  6. ReactNative学习之css样式使用

    前言: 前面学习了html,今天学习一下css的基本使用,看下html与css之间是如何结合来编写前端网页的. CSS 是什么? CSS 是 Cascading Style Sheets(级联样式表) ...

  7. Java Web 学习笔记 1

    Java Web 学习笔记 1 一.Web开发基础 1-1 Java Web 应用开发概述 1.1.1 C/S C/S(Client/Server)服务器通常采用高性能的PC机或工作站,并采用大型数据 ...

  8. WEB学习感受

    web学习感受 1.html前端知识比较好学,各种标签只需要记住关键的就行例如:body h1,p,div,tr,td,ul,li,就行了. 2.css学习前期还好, 后期关键布局和样式知识点较多,而 ...

  9. 零基础快速入门web学习路线(含视频教程)

    下面小编专门为广大web学习爱好者汇总了一条完整的自学线路:零基础快速入门web学习路线(含视频教程)(绝对纯干货)适合初学者的最新WEB前端学习路线汇总! 在当下来说web前端开发工程师可谓是高福利 ...

随机推荐

  1. MODIS批量处理软件MRT的安装说明

    最近在处理遥感影像的时候遇见了MODIS影像数据,从中MOD13中提取NDVI是相当的重要.在一番的百度之中找到了处理modis影像的神器------MRT 接下来我来说明一下MRT的具体安装,如果之 ...

  2. LAMP一键安装脚本 from:秋水逸冰

    Install LAMP(Linux + Apache + MySQL + PHP ) for CentOS/Redhat/Fedora 项目地址:https://github.com/teddysu ...

  3. sharepoint app 开发环境配置

    1. 配置脚本如下: .通过打开命令提示符并键入以下命令来确保 spadmin 和 sptimer 服务正在运行. net start spadminv4 net start sptimerv4 .作 ...

  4. [Android]Activity跳转传递任意类型的数据、Activity为SingleTask时代替StartActivityForResult的解决方案

    以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/4389674.html 需求:在ActivityA跳转到Acti ...

  5. yii cookie ,session 操作

    一,在Yii中使用session 1,CHttpSession 与原生态php5的session使用差别是,php5使用session_start();$_session['key'] = $valu ...

  6. Android开发学习——搭建开发环境

    在学校开课学习了android的一些简单的UI组件,布局,四大组件学习了2个,数据存储及网络通信,都是一些简单的概念,入门而已.许多东西需要自己去学习. 学习一下 Android开发环境的搭建,两种方 ...

  7. jax-rs中的一些参数标注简介(@PathParam,@QueryParam,@MatrixParam,@HeaderParam,@FormParam,@CookieParam)

    先复习一下url的组成: scheme:[//[user:password@]host[:port]][/]path[?query][#fragment] jax-rs anotation @Path ...

  8. HTTPS时代全面到来,你准备好了吗?

    近一年可能有很多朋友发现在使用百度搜索时,是这个样子的 如我们所见,浏览器地址栏里的HTTP可能将成为永远的过去时,取而代之的是更安全的HTTPS. 首先,HTTPS是什么? HTTPS是Http O ...

  9. OC字符串NSString

    ========================== 面向对象编程进阶和字符串 ========================== Δ一.类的设计模式—单例 [单例]程序允许过程中,有且仅有一块内存 ...

  10. OC中的Block的那些事

    Block封装了一段代码,可以在任何时候执行 Block可以作为函数参数或者函数的返回值,而其本身又可以带输入参数或返回值. 苹果官方建议尽量多用block.在多线程.异步任务.集合遍历.集合排序.动 ...