css样式中 li如何居中?

html-css08

css样式中 li如何居中?,第1张

1.文字居中定义

文字居中始终是要的,所以首先给予ul外层div一个text-align(文本对齐:居中),还可以给一个“溢位:隐藏(overflow: hidden)”,当然也可以定义一下高和宽。

2.ul定义

ul不能定义宽度,我们只能给一个定位,类型为相对(position: relative),置入左为50%(left: 50%),当然也可以给一个浮动。请注意,ul千万不能用溢位:隐藏(overflow: hidden),这样,部分li就无法显示。

3.li定义

li的定义跟ul差不多,宽度不固定,同样给一个定位,类型为相对(position: relative),置入右为50%(right: 50%),恰恰和ul相反,这样定义后li就可以无论分页多少始终居中了。

通常情况li上加float:left是为了让标签并排显示,如果不加的话默认就是换行的

而上面加position: relativeleft: -50%这个可能是写代码的人想让每个标签都向左移动一半的位置,有点像是书页或者纸张层叠的效果,也许可以不用相对定位来处理,可以加例如margin-left:-100px一样可以达到效果,只不过这样需要把li的宽度固定,要不然就效果不太好了

再来说一下让标签居中的样式好了,其实上面加的<ul style="position: relativeleft: 50%float:left">有点问题,加了position: relativeleft: 50%就没必要加 float:left了而且应该是无效的

还有就是position: relativeleft: 50%并不能达到真正居中的效果,因为这样加只是以标签的左边线为中心,实质效果是标签是偏右的,如果非要让标签用position来实现居中的话,那么就应该是下面这种样式,例如:<div style="position:absoluteleft:50%top:50%width:200pxheight:100pxmargin-left:-100pxmargin-top:-50pxbackground:red"></div>

你把这段标签直接放入body中试试就能看到了,div是绝对处于浏览器的居中位置

不过建议如果你想让标签居中,还是使用常用方法吧margin:0 auto,尽量少用position属性来设定,

列表<ul><li></li></ul>,其中ul是块级元素,li也是块级元素,怎么知道是不是块级元素?

给他们分别加上不同的background,给他们设定一定的width和height你就可以清晰的知道了。

li标签的css样式名称是current其中要说明的就是楼上说的有点小问题,li是dw的默认标签所以不需要调用class,直接设置完css之后li即可生效。不过它控制的是所有的li.如果要控制单个要分开定义css样式,然后再用class或id调用.