css的parent样式如何用

html-css07

css的parent样式如何用,第1张

css的parent样式如何用

directly?)

一般来说,当我们有一些应该一起设置样式的子元素时,我们应该将该样式放到父级并让继承工作,还是给孩子们自己? 例如,如果我们有如下结构:

<div class="foo">

<p>should be 2em</p>

<ul>

<li>should be 2em</li>

<li>should be 2em</li>

</ul>

</div>

然后我应该这样做:

.foo {font-size: 2em}

或类似的东西?:

.foo p, .foo li {font-size: 2em}

我认为这个问题非常基本,但很抱歉我找不到任何好的谷歌搜索结果。

Generally speaking, when we have some child elements that should be styled together, should we put that style to the parent and let the inheritance work, or to the children themselves? For example, if we have a structure as below:

<div class="foo">

<p>should be 2em</p>

<ul>

<li>should be 2em</li>

<li>should be 2em</li>

</ul>

</div>

then should I make it as this:

.foo {font-size: 2em}

or something like this?:

.foo p, .foo li {font-size: 2em}

I think this question is very basic, but sorry I couldn't find any good google result.

css常用的定位方式有五种:

1、static定位(普通流定位) -------------- 默认定位

2、float定位(浮动定位) 例:float:left

有两个取值:left(左浮动)和right(右浮动)。浮动元素会在没有浮动元素的上方,效果上看是遮挡住了没有浮动的元素,有float样式规则的元素是脱离文档流的,它的父元素的高度并不能有它撑开。

如果父元素的宽度太窄,那么其他浮动元素会向下移动,直到有足够的空间(左图所示);如果浮动元素的高度不同,那么其他浮动元素向下移动时,就有可能会出现卡住的情况(下图所示)

注意:浮动元素的外边缘不会超过父元素的内边缘;浮动元素不会上下浮动;浮动元素不会互相重叠,会像行内块元素一样排列。

如果想要既设置浮动,又使父元素的高度被浮动元素撑开,即清除子元素浮动对父元素带来的高度的影响,有四种方法可以实现:

假设HTML代码部分为:

<div class="parent">这是父元素

<div style="float:left">这是子元素</div>

</div>

1) 为父元素设置固定高度 -------------缺点:不知道具体高度没办法设置

CSS代码部分:

.parent{

//...

height:xxx//某个固定值

}

2) 在父元素内,在浮动元素的下方多写一行代码:<div style="clear:both"></div>------------- 缺点:增加代码冗余

HTML代码部分:

<div class="parent">这是父元素

<div style="float:left">这是子元素</div>

<div style="clear:both"></div>

</div>

3) 为父元素设置css规则:overflow:hidden ------------- 缺点:有时候不希望超出部分隐藏

.parent{

// ...

overflow:hidden //某个固定值

}

4) 内容生成 ------------- 最优的方法,推荐

CSS代码部分:

.parent:after{

content:''

display:'block'

clear:both

}

3、relative定位(相对定位) position:relative

相对本元素的左上角进行定位,top,left,bottom,right都可以有值。虽然经过定位后,位置可能会移动,但是本元素并没有脱离文档流,还占有原来的页面空间。可以设置z-index。使本元素相对于文档流中的元素,或者脱离文档流但是z-index的值比本元素的值要小的元素更加靠近用户的视线。

相对定位最大的作用是为了实现某个元素相对于本元素的左上角绝对定位,本元素需要设置position为relative。

4、absolute定位(绝对定位) position:absolute

相对于祖代中有relative(相对定位)并且离本元素层级关系上是最近的元素的左上角进行定位,如果在祖代元素中没有有relative定位的,就默认相对于body进行定位。

5、fixed定位(固定定位)position:fixed

相对于窗口的位置,而且不受其他网页内元素影响,永远处于浏览器窗口的相对位置。

绝对定位是脱离文档流的,与浮动定位是一样的效果,会压在非定位元素的上方。可以设置z-index属性。

注意:当同时有浮动元素和绝对定位元素出现并且浮动元素没有设置z-index,浮动元素是压在绝对定位元素上的,即离用户的视线更近。