关于CSS样式问题

html-css017

关于CSS样式问题,第1张

div div.rtop,div div.rbottom{ background-color:white} 背景:白 也可以用#ffee00 或者#fe0 表示,方法很多

div.rtop div ,div.rbottom div {

display:block这个(div)元素之后,会新起一行,其实默认就是block

height:1px高1px

overflow:hidden内部超出边框部分内容 隐藏

background:#cc3333} 背景

div.r1 {margin:0 5px外轮廓 上下为0 左右为5px

}

仅供参考

推荐这个,搜索 "css 苏昱", 很全,而且里面有例子

我们先看一下position属性的几个取值定义:

position: static、absolute、relative

static : 默认值。如果没有指定position属性,支持position属性的html对象都是默认为static,可以这么理解:把html页面看作一个文档流,源代码中各个标签的先后位置就是它们所对应的对象的呈现次序,所有取值为static的对象都按照你所编写的html标签的顺序依次呈现。

如下图所示,这是一个常见的指定了float:left的横向导航:

relative: 相对定位。这个属性值保持对象所在文档流中的位置,也就是说它具有和static相同的呈现方式,它同样占有在文档流中的固定位置,后面的对象不会侵占或覆盖;与static属性值不同的是,设置了relative的对象,可以通过top, left, right, bottom属性设定自己的新显示位置,这4个属性的取值是相对于文档流的前一个对象的,你可以自由设置这4个属性偏移到新的位置而不对文档流中的其他对象产生任何影响,原来的页面呈现仍然会我行我素:

absolute: 绝对定位。和relative不同的是,这个属性值会将当前对象拖出文档流,后面的对象会占有原来的位置,也就是说,当前对象的呈现是独立显示的,但是它的位置在指定top, left, right, bottom任一属性之前仍是有继承性的,这时的4个属性的取值是相对于浏览器的,和文档流无关了。如果把示例中的B区域设定为absolute而不指定 4个位置属性,通过设定margin来改变它的相对位置,用这个方法可以解决前面提到的问题2。

提示a: 苏昱的css2.0手册中提到relative和absolute定位的滚动条区别不是绝对的,至少在firefox、opera和safari中滚动条该出现还是会出现。

提示b: 属性值为absolute对象的z-index属性可以设置层叠显示的次序,它是直接有效的;

而属性值为relative对象的z-index属性在设置时要小心,把当前对象的z-index设置为-1是不行的,在firefox中它会无法显示,必须设置为0以上,我们如果想让别的对象挡住它,只有将其他对象也设置position为relative,并将z-index属性取一个比它大的值即可。

上面的表述不知道也许不是很清晰,具体的理解还是要自己亲自动手操作一下。

这样看来,前面的问题就有解了,问题3我们可以根据设计的要求将其设置为相对或绝对定位;

问题1的解决方法也有很多,个人推荐使用有语义的dl, dt, dd来实现,而且这个方法在不同浏览器中的表现基本相同(已在ie, firefox, opera, safari中测试),仅在top的属性上有几像素的差异,由于时间关系我只能给出自己测试时的代码以供参考:

body {

color:#fff

font-size:12px

}

ul li {

float:left

height:30px

background-color:#99CC99

margin:0 10px

padding:0

border:1px solid #c30

width:100px

}

ul li div {

border:1px solid #f00

background-color:#996666

width:100px

height:100px

position:absolute

margin-top:15px

margin-left:-1px

*margin-left:-79px

}

ul li dl,

ul li dl dt,

ul li dl dd {

margin:0

padding:0

}

ul li dl dd {

border:1px solid #f00

background-color:#996666

width:100px

height:100px

position:absolute

margin-top:11px

*margin-top:10px

margin-left:-1px

}

<ul>

<li>

标题 - #text

<div>

下拉菜单 - div

</div>

</li>

<li style="position:relative">列表b</li>

<li>列表c</li>

<li>

<dl>

<dt>标题 - dt</dt>

<dd>下拉菜单 - dd</dd>

</dl>

</li>

</ul>