手机版 欢迎访问it开发者社区(www.mfbz.cn)网站

当前位置: > 开发

Internet学习记录:层叠样式表——CSS简介

时间:2021/4/10 8:30:14|来源:|点击: 次

层叠样式表——CSS简介

  • 层叠样式表——CSS
  • 什么是DOCTYPE
  • 调用样式表
  • head区的其他设置
  • XHTML代码规范
  • CSS样式规则
  • CSS基本语法规范
  • 群选择器
  • 派生选择器
  • id选择器
  • 类别选择器
  • CSS布局入门
    • 定义DIV
    • CSS2盒模型
    • 辅助图片一律用背景处理
  • CSS布局实例

层叠样式表——CSS

  • 层叠样式表(英语:Cascading Style Sheets, 简写CSS),又称串样式列表,由W3C定义和维护的标准,一种用来为结构化文档(如HTML文档或XML应用)添加样式(字体、间距和颜色等)的计算机语言
  • 目前版本是CSS2.1,为W3C的推荐标准。CSS3现在已被大部分现代浏览器支援,而下一版的CSS4仍在开发过程中
  • CSS最主要的目的是将文件的结构(用HTML或其他相关的语言写的)与文件的显示(CSS)分隔开来。这个分隔有许多好处:
    • 文件的可读性被加强
    • 文件的结构更加灵活
    • 作者和读者可以自己决定文件的显示
    • 文件的结构简化了

什么是DOCTYPE

  • DOCTYPE是document type(文档类型)的简写,用来说明你用的XHTML或者HTML是什么版本。其中的DTD叫文档类型定义,里面包含了文档的规则,浏览器就根据你定义的DTD 来解释你页面的标识,并展现出来。 要建立符合标准的网页,DOCTYPE声明是必不可少的关键组成部分;除非你的XHTML确定了一个正确的DOCTYPE,否则你的标识和CSS
    都不会生效。 XHTML 1.0 提供了三种DTD声明可供选择:
  • 过渡的(Transitional):要求非常宽松的DTD,它允许你继续使用HTML4.01的标识(但是要符合xhtml的写法)。完整代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0
Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1- transitional.dtd">
  • 严格的(Strict):要求严格的DTD,你不能使用任何表现层的标识和属性,例如<br>。完整代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
  • 框架的(Frameset):专门针对框架页面设计使用的DTD,如果你的页面中包含有框架,需要采用这种DTD。完整代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd">

调用样式表

  • 页面内嵌法:就是将样式表直接写在页面代码的head区。类似这样:
<style type="text/css"> <!-- body { background : white ; color : black ; } --> </style>
  • 外部调用法:将样式表写在一个独立的.css文件中,然后在页面head区用类似以下代码调用。
<link rel="stylesheet" rev="stylesheet" href="css/style.css" type="text/css" media="all"
/>
  • 双表法调用样式表:
<link rel="stylesheet" rev="stylesheet" href="css/style.css" type="text/css" media="all" />
<style type="text/css" media="all">@import url( css/style01.css );</style>

head区的其他设置

  • 收藏夹小图标
<link rel="icon" href="/favicon.ico" type="image/x-icon" />
<link rel="shortcut icon" href="/favicon.ico" type="image/x-icon" />
  • 为搜索引擎准备的内容
    • 允许搜索机器人搜索站内所有链接。如果你想某些页面不被搜索, 推荐采用robots.txt方法
    <meta content="all" name="robots" />
    
    • 设置站点作者信息
    <meta name="author" content=“yourname@example.com,name" />
    
    • 设置站点版权信息
    <meta name="Copyright" content=“www.example.com,自由版权,任意转载" />
    
    • 站点的简要介绍(推荐)
    <meta name="description" content=“descript your site" />
    
    • 站点的关键词(推荐)
    <meta content=“example, test,…" name="keywords" />
    

XHTML代码规范

  • 所有的标记都必须要有一个相应的结束标记
  • 所有标签的元素和属性的名字都必须使用小写
  • 所有的XML标记都必须合理嵌套
  • 所有的属性必须用引号""括起来
  • 把所有<和&特殊符号用编码表示
  • 给所有属性赋一个值
  • 不要在注释内容中使“–”

CSS样式规则

  • 样式控制
    • 一个式样表由一组规则组成。每个规则由一个“选择器”(selector)和一个定义部分组成。每个定义部分包含一组由半角分号(;)分离的定义。这组定义放在一对大括号({ }) 之间。每个定义由一个特性,一个半角冒号(:)和一个值组成
  • 选择器(Selector)
    • 通常为档中的元素(element),如HTML中的<body>,<p>,<strong>等标签,多个选择器可以半角逗号(,)隔开
  • 属性(property)
    • CSS1、CSS2、CSS3规定了许多的属性,目的在控制选择器的样式
  • 值(value)
    • 指属性接受的设定值,可由各种关键字(keyword)组成, 多个关键字时大都以空格隔开

CSS基本语法规范

  • 分析一个典型CSS的语句:p {color:#FF0000; background:#FFFFFF}
  • 其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式
  • 样式声明写在一对大括号"{}"中
  • color和background称为"属性"(property),不同属性之间用分号";"分隔
  • “#FF0000"和”#FFFFFF"是属性的值(value)

群选择器

  • 当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:p, td, li { font-size : 12px ; }

派生选择器

  • 可以使用派生选择器给一个元素里的子元素定义样式,例如这样:
li strong { font-style : italic; font-weight : normal;}
  • 就是给li下面的子元素strong定义一个斜体不加粗的样式

id选择器

  • 用CSS布局主要用层“div”来实现,而div的样式通过“id选择器”来定义。例如我们首先定义一个层
<div id="menubar"></div>
  • 然后在样式表里这样定义:
#menubar {
margin: 0px; background : #FEFEFE; color: #666;}
  • 其中"menubar"是你自己定义的id名称。注意在前面加"#"号

类别选择器

  • 在CSS里用一个点开头表示类别选择器定义, 例如:
.14px {color : #f60; font-size:14px ;}
  • 在页面中,用class="类别名"的方法调用:
<span class="14px">14px大小的字体</span>
  • 这个方法比较简单灵活,可以随时根据页面需要新建和删除

CSS布局入门

  • CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:
a:link{font-weight : bold ;text-decoration : none ;color : #c00 ;} a:visited {font-weight : bold ;text-decoration : none ;color :
#c30 ;}
a:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
a:active {font-weight : bold ;text-decoration : none ;color : #F90 ;}
  • 以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样,记住它们的顺序是“LVHA”
  • CSS布局与传统表格(table)布局最大的区别在于:原来的定位都是采用表格,通过表格的间距或者用无色透明的GIF图片来控制文布局版块的间距;而现在则采用层(div)来定位,通过层的margin,padding,border等属性来控制版块的间距

定义DIV

分析一个典型的定义div例子:

#sample{ margin: 10px 10px 10px 10px; 
padding:20px 10px 10px 20px;
border-top: #CCC 2px solid; 
border-RIGHT: #CCC 2px solid; border-BOTTOM: #CCC 2px solid; 
border-LEFT: #CCC 2px solid;
background: url(images/bg_poem.jpg) #FEFEFE no-repeat right bottom;
color: #666;
text-align: center;
line-height: 150%; WIDTH:60%; }

CSS2盒模型

盒模型主要定义四个区域:
内容(content) 边框距(padding) 边界(border) 边距(margin)。
盒模型

辅助图片一律用背景处理

用XHTML+CSS布局,有一个技术一开始让你不习惯,应该说是一种思维方式与传统表格布局不一样,那就是:所有辅助图片都用背景来实现。类似这样:

BACKGROUND: url(images/bg_poem.jpg) #FEFEFE no-repeat right bottom;

CSS布局实例

示例

│body {} /*这是一个HTML元素*/
└#Container {} /*页面层容器*/
├#Header {} /*页面头部*/
├#PageBody {} /*页面主体*/
│ ├#Sidebar {} /*侧边栏*/
│ └#MainBody {} /*主体内容*/
└#Footer {} /*页面底部*/
 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0
Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1- transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
<link href="css.css" rel="stylesheet" type="text/css" />
</head>
<body>
</body>
</html>

在<body></body>标签对中写入DIV的基本结构
<div id="container">[color=#aaaaaa]<!--页面层容器-->[/color]
<div id="Header">[color=#aaaaaa]<!--页面头部-->[/color] </div>
<div id="PageBody">[color=#aaaaaa]<!--页面主体-->[/color]
<div id="Sidebar">[color=#aaaaaa]<!--侧边栏-->[/color] </div>
<div id="MainBody">[color=#aaaaaa]<!--主体内容-->[/color] </div>
</div>
<div id="Footer">[color=#aaaaaa]<!--页面底部-->[/color] </div>
</div>

css.css文件
/*基本信息*/
body {font:12px Tahoma;margin:0px;text-align:center;background:#FFF;}
/* 页 面 层 容 器 */ #container {width:100%} /
*页面头部*/
#Header {width:800px;margin:0 auto;height:100px;background:#FFCC99}
/*页面主体*/
#PageBody {width:800px;margin:0 auto;height:400px;background:#CCFF00} /
*页面底部*/
#Footer {width:800px;margin:0 auto;height:50px;background:#00FFFF}

Copyright © 2002-2019 某某自媒体运营 版权所有