1、 css基础语法:
CSS 语法——CSS 规则由两个主要的部分构成:选择器,以及一条或多条声明。
值的不同写法和单位。——p { color: #ff0000; }或p { color: #f00; };p { color: rgb(255,0,0); }或p { color: rgb(100%,0%,0%); }
提示:如果值为若干单词,则要给值加引号:p {font-family: "sans serif";}
多重声明:提示:如果要定义不止一个声明,则需要用分号将每个声明分开。
空格与大小写——多重声明和空格的使用使得样式表更容易被编辑;CSS 对大小写不敏感,不过存在一个例外:如果涉及到与 HTML 文档一起工作的话,class 和 id 名称对大小写是敏感的。 继承——
2、 派生选择器:
<li><strong>我是斜体字。这是因为 strong 元素位于 li 元素内。</strong></li>
li strong {
font-style: italic;
font-weight: normal;
}
3、 id选择器:
3.1在现代布局中,id 选择器常常用于建立派生选择器。
#sidebar p {
font-style: italic;
text-align: right;
margin-top: 0.5em;
}
3.2 id 选择器即使不被用来创建派生选择器,它也可以独立发挥作用。
#sidebar {
border: 1px dotted #000;
padding: 10px;
}
老版本的 Windows/IE 浏览器可能会忽略这条规则,除非你特别地定义这个选择器所属的元素:
div#sidebar {
border: 1px dotted #000;
padding: 10px;
}
4、属性选择器:注释:只有在规定了 !DOCTYPE 时,IE7 和 IE8 才支持属性选择器。在 IE6 及更低的版本中,不支持属性选择。 CSS 选择器参考手册
选择器 描述
[attribute]
用于选取带有指定属性的元素。
[attribute=value]
用于选取带有指定属性和值的元素。
[attribute~=value]
用于选取属性值中包含指定词汇的元素。
[attribute|=value]
用于选取带有以指定值开头的属性值的元素,该值必须是整个单词。
[attribute^=value]
匹配属性值以指定值开头的每个元素。
[attribute$=value]
匹配属性值以指定值结尾的每个元素。
[attribute*=value]
匹配属性值中包含指定值的每个元素。
5、背景关联
background-attachment
属性的默认值是 scroll
,也就是说,在默认的情况下,背景会随文档滚动。
background-attachment
: fixed
;声明图像相对于可视区是固定的,不会受到滚动的影响。
6、css文本
text-indent
: 可以继承
注意:一般来说,可以为所有块级元素应用 text-indent
,但无法将该属性应用于行内元素,图像之类的替换元素上也无法应用 text-indent
属性。不过,如果一个块级元素(比如段落)的首行中有一个图像,它会随该行的其余文本移动。
提示:如果想把一个行内元素的第一行“缩进”,可以用左内边距或外边距创造这种效果。
text-align: left | right | center | justify | inherit
;不会控制元素的对齐,而只影响内部内容。元素本身不会从一端移到另一端,只是其中的文本受影响。
提示:将块级元素或表元素居中,要通过在这些元素上适当地设置左、右外边距来实现。
word-spacing
属性可以改变字(单词)之间的标准间隔。其默认值 normal 与设置值为 0 是一样的。
word-spacing 属性接受一个正长度值或负长度值。如果提供一个正长度值,那么字之间的间隔就会增加。为 word-spacing 设置一个负值,会把它拉近.
letter-spacing
属性与 word-spacing
的区别在于,字母间隔修改的是字符或字母之间的间隔。
text-transform
属性处理文本的大小写。这个属性有 4 个值:none | uppercase | lowercase | capitalize
text-decoration
属性文本修饰,5个值:none | underline | overline | line-through | blink
可以在一个规则中结合多种装饰。则规则如下:a:link a:visited {text-decoration: underline overline;} 不过要注意的是,如果两个不同的装饰都与同一元素匹配,胜出规则的值会完全取代另一个值。如:
h2.stricken {text-decoration: line-through;}
h2 {text-decoration: underline overline;}
对于给定的规则,所有 class 为 stricken 的 h2 元素都只有一个贯穿线装饰,而没有下划线和上划线,因为 text-decoration 值会替换而不是累积起来。
white-space
属性会影响到用户代理对源文档中的空格、换行和 tab 字符的处理。——处理空白符。
下面的表格总结了 white-space 属性的行为:
值 | 空白符 | 换行符 | 自动换行 |
---|---|---|---|
pre-line | 合并 | 保留 | 允许 |
normal | 合并 | 忽略 | 允许 |
nowrap | 合并 | 忽略 | 不允许 |
pre | 保留 | 保留 | 不允许 |
pre-wrap | 保留 | 保留 | 允许 |
direction 属性影响块级元素中文本的书写方向、表中列布局的方向、内容水平填充其元素框的方向、以及两端对齐元素中最后一行的位置。
注释:对于行内元素,只有当 unicode-bidi
属性设置为 embed
或 bidi-override
时才会应用 direction
属性。
direction
属性有两个值:ltr
和 rtl
。大多数情况下,默认值是 ltr,显示从左到右的文本。如果显示从右到左的文本,应使用值 rtl。
CSS 文本属性
属性 描述
color
设置文本颜色
direction
设置文本方向。
line-height
设置行高。
letter-spacing
设置字符间距。
text-align
对齐元素中的文本。
text-decoration
向文本添加修饰。
text-indent
缩进元素中文本的首行。
text-shadow
设置文本阴影。CSS2 包含该属性,但是 CSS2.1 没有保留该属性。
text-transform
控制元素中的字母。
unicode-bidi
设置文本方向。
white-space
设置元素中空白的处理方式。
word-spacing
设置字间距。
7,css 字体
font-variant
属性可以设定小型大写字母。小型大写字母不是一般的大写字母,也不是小写字母,这种字母采用不同大小的大写字母。
p {font-variant:small-caps;}
font-weight
属性设置文本的粗细。关键字 100 ~ 900 为字体指定了 9 级加粗度。100 对应最细的字体变形,900 对应最粗的字体变形。数字 400 等价于 normal,而 700 等价于 bold。
font-size
属性设置文字的大小。注意:如果您没有规定字体大小,普通文本(比如段落)的默认大小是 16 像素 (16px=1em)。
浏览器中默认的文本大小是 16 像素。因此 1em 的默认尺寸是 16 像素。
可以使用下面这个公式将像素转换为 em:pixels/16=em
(注:16 等于父元素的默认字体大小,假设父元素的 font-size 为 20px,那么公式需改为:pixels/20=em)
CSS 字体属性
属性 描述
font
简写属性。作用是把所有针对字体的属性设置在一个声明中。
font-family
设置字体系列。
font-size
设置字体的尺寸。
font-size-adjust
当首选字体不可用时,对替换字体进行智能缩放。(CSS2.1 已删除该属性。)
font-stretch
对字体进行水平拉伸。(CSS2.1 已删除该属性。)
font-style
设置字体风格。
font-variant
以小型大写字体或者正常字体显示文本。
font-weight
设置字体的粗细。
设置链接不同样式是遵循的顺序:
- a:hover 必须位于 a:link 和 a:visited 之后
- a:active 必须位于 a:hover 之后
a:link {text-decoration:none;} a:visited {text-decoration:none;} a:hover {text-decoration:underline;} a:active {text-decoration:underline;}
8,CSS padding
属性
CSS padding
属性定义元素的内边距。padding
属性接受长度值或百分比值,但不允许使用负值。各边均可以使用不同的单位或百分比值:h1 {padding: 10px 0.25em 2ex 20%;}。百分数值是相对于其父元素的 width 计算的,这一点与外边距一样。
注意:上下内边距与左右内边距一致;即上下内边距的百分数会相对于父元素宽度设置,而不是相对于高度。
9,CSS 定位属性
CSS 定位属性允许你对元素进行定位。
属性 描述
position
把元素放置到一个静态的、相对的、绝对的、或固定的位置中。
top
定义了一个定位元素的上外边距边界与其包含块上边界之间的偏移。
right
定义了定位元素右外边距边界与其包含块右边界之间的偏移。
bottom
定义了定位元素下外边距边界与其包含块下边界之间的偏移。
left
定义了定位元素左外边距边界与其包含块左边界之间的偏移。
overflow
设置当元素的内容溢出其区域时发生的事情。
clip
设置元素的形状。元素被剪入这个形状之中,然后显示出来。
vertical-align
设置元素的垂直对齐方式。
z-index
设置元素的堆叠顺序。
10,伪类
W3C:"W3C" 列指示出该属性在哪个 CSS 版本中定义(CSS1 还是 CSS2)。
属性 描述 CSS
:active
向被激活的元素添加样式。 1
:focus
向拥有键盘输入焦点的元素添加样式。 2
:hover
当鼠标悬浮在元素上方时,向元素添加样式。 1
:link
向未被访问的链接添加样式。 1
:visited
向已被访问的链接添加样式。 1
:first-child
向元素的第一个子元素添加样式。 2
:lang
向带有指定 lang 属性的元素添加样式。 2
11,伪元素
W3C:"W3C" 列指示出该属性在哪个 CSS 版本中定义(CSS1 还是 CSS2)。
属性 描述 CSS
:first-letter
向文本的第一个字母添加特殊样式。 1
:first-line
向文本的首行添加特殊样式。 1
:before
在元素之前添加内容。 2
:after
在元素之后添加内容。 2