博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
不固定个数的子元素自适应居中
阅读量:6199 次
发布时间:2019-06-21

本文共 2025 字,大约阅读时间需要 6 分钟。

 

今天工友提了一个需求,让固定宽度的子元素,在不确定宽度的容器内水平居中(自适应):UL 宽度不固定;LI 宽度固定,LI 是一个块。看起来还挺简单的。但大家为什么一直讨论不断。希奇,实现了一下。发现实在还是很简单的。还是没有超出原来的解决方案,即使用 display:inline-block。实际要实现的效果应该是下面这个样子:

而事实上,这并不是简单的事。作为样式方面的主导者开发者,职责就是往解决这样的题目。那么写 Demo 吧。假如这个解决方案搞定了,那么,我们将可以轻易地做到,让不固定个数的子元素相对于窗口自适应居中。比如这样的导航,无论子元素是多少,都会自适应居中:

终极效果:UL宽度自适应水平居中

说一下实现的重点。假如子元素不是固定的话,我们通常的实现方法是利用来 display:inline-block 解决,在 IE6 ~ 7 中使用 display:inline 但要让这个元素拥有 layout,通常我们是添加 zoom:1; 来实现。这样,大概代码会是这样的:

 

以下为引用的内容:

#test{display:block;text-align:center;}

#test li{display:inline-block;*display:inline;*zoom:1;width...

 

但这个子元素需要是块状的,有时候就会现出高低不平的现象,这很好解决,用加上一句:

 

以下为引用的内容:

#test{display:block;text-align:center;}

#test li{
    display:inline-block;*display:inline;*zoom:1;

    /* 解决不能水平对齐题目 */

    vertical-align:top;
}

 

好吧,现在能运行了。样子还不错,IE 下面已经可以达到我们要求的效果了。但,Firefox 等高级浏览器竟然出现了间隙,如下图:

 
摘要: 真正要忧伤的东西来了。这是一个正常现象,只要用 display:inline-block 就会有这样的题目。由于 IE6~7 并不完全支持这个属性,所以不存在这样的题目。好吧

 

真正要忧伤的东西来了。这是一个正常现象,只要用 display:inline-block 就会有这样的题目。由于 IE6~7 并不完全支持这个属性,所以不存在这样的题目。好吧,似乎是由于空缺引起的。假如把所有空缺都删除了就没题目了。但这始终不是什么好办法。我们的解决方法是(多谢@鸽子一起解决这个题目):

 

以下为引用的内容:

@media screen and (-webkit-min-device-pixel-ratio:0){

    #test{
        /* 让 chrome 支持 12px 以下的字体 */
        -webkit-text-size-adjust:none;
    }
 }

 

但是,题目是这个纠结的浏览器,竟然不认 font-size:0 这样的写法。还好经测试,幸运的是 font-size:1px 它熟悉,而且效果恰好是我们想要的:没有间隙。终极的代码是:

 

以下为引用的内容:

#test{

    display:block;text-align:center;

    /* 解决间隙题目 */

    font-size:0;
}
#test li{
    display:inline-block;*display:inline;*zoom:1;

    /* 解决不能水平对齐题目 */

    vertical-align:top;

    /* 解决间隙题目后遗症解决 */

    font-size:13px;
}

/* 让 chrome 支持 12px 以下的字体 */

@media screen and (-webkit-min-device-pixel-ratio:0){
    #test{-webkit-text-size-adjust:none;font-size:1px;}
}

 

好久没写 CSS 了。在想,假如有天我开始记忆力不好,忘记 CSS 是怎么写的,怎么办?会不会像《Boston Legal》的 Deny Crane 一样抓狂。

UPDATE: 2011.1.25 21:15

多谢 Atrl 同学和Justice 同学提供的更方便的方法,避免了 hack: 以下为引用的内容: ul{ float: left; left: 50%; position: relative; } li{ float: left; position: relative; right: 50%; }

Justice 同学提供的更方便的方法,避免了 hack:

以下为引用的内容:

ul{ float: left;

    left: 50%;
    position: relative;
}
li{
    float: left;
    position: relative;
    right: 50%;
}

 

 

转载地址:http://xxtca.baihongyu.com/

你可能感兴趣的文章
Linux下C编程的学习_1
查看>>
Http标准协议Android网络框架——NoHttp
查看>>
CathyCMS-后台管理v1.0
查看>>
redis的安装
查看>>
Zookeeper源码编译为Eclipse工程(win7下Ant编译)
查看>>
Spring Boot 2.0 学习专栏
查看>>
VIM Quick Reference Card
查看>>
[Python]datetime常用的几个操作
查看>>
WCF学习心得--客户端获取服务端自定义类数据
查看>>
C#中的线程四(System.Threading.Thread)
查看>>
【187】◀▶ 编辑博客的文本格式 & 装饰
查看>>
Android解析服务器Json数据实例
查看>>
【Nodejs】使用nimble串行化回调任务
查看>>
Redis介绍、安装部署、操作
查看>>
css网页布局教程:弹性+固宽布局
查看>>
第一次学会用了VBA
查看>>
求两个或N个数的最大公约数(gcd)和最小公倍数(lcm)的较优算法
查看>>
博客网址收集
查看>>
globalization与全球化
查看>>
远程执行命令和文件分发shell脚本
查看>>