热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

css点滴2—六种方式实现元素水平居中

本文参考文章《六种方式实现元素水平居中》元素水平居中的方法,最常见的莫过于给元素一个显式的宽度,然后加上margin的左右值为auto。这种方式给固定宽度的元素设置居中是最方便不过的。但是很多情况

本文参考文章《六种方式实现元素水平居中》

元素水平居中的方法,最常见的莫过于给元素一个显式的宽度,然后加上margin的左右值为auto。这种方式给固定宽度的元素设置居中是最方便不过的。但是很多情况下,无法确定容器宽度,这里我们讨论一下这些问题。

为了更好说明问题,我们看一个制作分页效果的代码:

html代码:

<div class="pagination">
    <ul>
        <li>
            <a href="#">Preva>li>
        <li>
            <a href="#">1a>li>
        <li>
            <a href="#">2a>li>
        <li>
            <a href="#">3a>li>
        <li>
            <a href="#">4a>li>
        <li>
            <a href="#">5a>li>
        <li>
            <a href="#">Nexta>li>
    ul>
div>

css代码:

        .pagination a {
            display: block;
            color: #f2f2f2;
            text-shadow: 1px 0 0 #101011;
            padding: 0 10px;
            border-radius: 2px;
            box-shadow: 0 1px 0 #5a5b5c inset,0 1px 0 #080808;
            background: linear-gradient(to top,#434345,#2f3032);
            text-decoration: none;
        }
        .pagination a:hover {
            text-decoration: none;
            box-shadow: 0 1px 0 #f9bd71 inset,0 1px 0 #0a0a0a;
            background: linear-gradient(to top,#f48b03,#c87100);
        }
        li {
            list-style: none;
        }

效果:

这显然不是我们想要的效果,接下来我们分几种方案来实现水平居中。下面css代码我们只贴出关键代码。

1.margin和width实现水平居中

第一种方式是最古老的实现方案,也是最常见的,在分页容器上定义一个宽度,然后配合margin的左右值为“auto”实现效果。

css代码:

        .pagination li {
            line-height: 25px;
            list-style: none;
            display: inline;
            float: left;
            margin: 0 5px;
        }
        /*!*给容器一个宽度*!*/
        .pagination {
            width: 500px;
            margin-left: auto; /**/
            margin-right: auto;
        }

效果:

 

 

 效果是实现了,但是扩展性不一定强。这种方式显示了5个分页和首页,末页共7个显示项,往往我们无法知道到底要显示多少个分页项,无法确定每个分页项的宽度是多少,也就无法确定容器的宽度。

缺点:这种方法简单易懂,浏览器兼容性强,但是扩展性差,无法自适应未知情况。

2.inline-block实现水平居中

这种方式使用inline-block和text-align:center结合起来实现水平居中。

css代码:

.pagination{
            text-align: center;
            font-size: 0;
            letter-spacing: -4px;
            word-spacing: -4px;
        }
        .pagination li {
            line-height: 25px;
            margin: 0 5px;
            display: inline-block;
            *display: inline;
            zoom: 1;
            letter-spacing: normal;
            word-spacing: normal;
            font-size: 12px;
        }

效果:

 

 

 这种方法相对来说简单,但是使用inline-block实现了水平居中的问题,却又产生了一个新的问题,就是分页项之间的回车符带来的空白间距,这个间距也不是所有浏览器都会有,所以要解决下inline-block带来的间距,详细解决方法参考《如何解决inline-block元素的空白间距》

缺点:这种方法简单易懂,扩展性强,但是需要额外处理inline-block的空白间距。

3.浮动实现水平居中

float浮动要么考左,要么靠右,没有居中选项,其实只要略加处理就可以了。

css代码:

        .pagination {
            float: left; /*分页容器浮动到左边*/
            width: 100%; /*分页容器宽度为100%*/
            overflow: hidden;
            position: relative; /*相对正常位置定位*/
        }
        .pagination ul {
            clear: left;
            float: left; /*内部容器浮动到左边*/
            position: relative; /*相对正常位置定位*/
            left: 50%; /* 整个内部容器向右边移动宽度的50% */
            text-align: center;
        }
        .pagination li {
            line-height: 25px;
            margin: 0 5px;
            display: block;
            float: left; /*每个分页也浮动到左边*/
            position: relative; /*相对正常位置定位*/
            right: 50%; /* 每个分页项向左移动宽度的50% */
        }

效果:

这种方法和前面的都不同,使用浮动float配合position:relative相对自身定位来实现,下面的文章介绍了这种方法的实现原理《Horizontally Centered Menus with no CSS hacks》

div是一个块元素,其默认宽度是100%,如图所示:

如果给div设置了浮动之后,他的内容有多宽就会撑开多大的容器(除显式设置元素宽度值之外),这也是让分页导航居中的关键:

接下来使用传动的制作方法,让导航浮动到左边,而且每个分页也进行浮动

现在要想的办法是让分页导航居中的效果,这里是通过“position:relative”属性实现,首先在列表项ul上向右移动50%(left:50%),如下图:

如上图一样整个分页向右移动了50%的距离,接着我们在“li”上也定义“position:relative”属性,但其移动方向和列表“ul”移动方向刚好相反,而且移动值保持一致:

这样就实现了float浮动居中的效果。

缺点:这种方式实现的兼容性强,扩展性强,但是实现原理比较复杂。

4.绝对定位实现水平居中

绝对定位实现水平居中,元素绝对定位:“position:absolute;”,向右移动50%:“left:50%;” ,设置固定宽度:“width:宽度值;”,设置左外边距为宽度值的一半:“margin-left:-(宽度值/2);”,代码如下:

.ele {
    position: absolute;
    width: 宽度值;
    left: 50%;
    margin-left: -(宽度值/2);
}

但是这种做法有一个缺点,大多数情况下我们不知道元素的宽度,或者元素宽度是不固定的,但是我们可以在第三种方法的基础上做一点变通:
css代码:

        .pagination {
            position: relative; /*div相对定位*/
        }
        .pagination ul {
            position: absolute; /*分页容器绝对定位*/
            left: 50%; /*分页容器向右移动50%*/
        }
        .pagination li {
            line-height: 25px;
            margin: 0 5px;
            position: relative; /*分页元素相对定位,注意这里不是absolute*/
            float: left; /*分页元素浮动在右边*/
            right: 50%; /*分页元素向左移动50%*/
        }

效果:

 

 缺点:这种方式扩展性强,兼容性强,但是理解起来比较难。

5.css3的flex实现水平居中

css3的flex是一个很强大的功能,能让布局变得灵活方便,唯一的缺点就是目前兼容性差。

css代码:

        .pagination{
            display: -webkit-box;
            -webkit-box-orient: horizontal;
            -webkit-box-pack: center;
            display: -moz-box;
            -moz-box-orient: horizontal;
            -moz-box-pack: center;
            display: -o-box;
            -o-box-orient: horizontal;
            -o-box-pack: center;
            display: -ms-box;
            -ms-box-orient: horizontal;
            -ms-box-pack: center;
            display: box;
            box-orient: horizontal;
            box-pack: center;

        }
        .pagination li {
            line-height: 25px;
            margin: 0 5px;
            float: left;
        }

效果:

 

 缺点:这种方法实现起来比较便捷,扩展性强,但是兼容性比较差。

6.css3的fit-content实现水平居中

这种实现居中的方法参考《Horizontal centering using CSS fit-content value》。“fit-content”是给css的“width”属性增加一个属性值,也配合margin可以轻松的实现水平居中的效果。

        .pagination ul {
            width: -moz-fit-content;
            width: -webkit-fit-content;
            width: fit-content; /*给with属性值设置为fit-content*/
            margin: 0 auto;
        }
        .pagination li {
            line-height: 25px;
            margin: 0 5px;
            float: left;
        }

效果:

 

 缺点:这种方式简单易懂,扩展性强,缺点是兼容性差。

 


推荐阅读
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • OpenMap教程4 – 图层概述
    本文介绍了OpenMap教程4中关于地图图层的内容,包括将ShapeLayer添加到MapBean中的方法,OpenMap支持的图层类型以及使用BufferedLayer创建图像的MapBean。此外,还介绍了Layer背景标志的作用和OMGraphicHandlerLayer的基础层类。 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了css回到顶部按钮相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 推荐系统遇上深度学习(十七)详解推荐系统中的常用评测指标
    原创:石晓文小小挖掘机2018-06-18笔者是一个痴迷于挖掘数据中的价值的学习人,希望在平日的工作学习中,挖掘数据的价值, ... [详细]
  • Tomcat/Jetty为何选择扩展线程池而不是使用JDK原生线程池?
    本文探讨了Tomcat和Jetty选择扩展线程池而不是使用JDK原生线程池的原因。通过比较IO密集型任务和CPU密集型任务的特点,解释了为何Tomcat和Jetty需要扩展线程池来提高并发度和任务处理速度。同时,介绍了JDK原生线程池的工作流程。 ... [详细]
  • 本文介绍了Java的集合及其实现类,包括数据结构、抽象类和具体实现类的关系,详细介绍了List接口及其实现类ArrayList的基本操作和特点。文章通过提供相关参考文档和链接,帮助读者更好地理解和使用Java的集合类。 ... [详细]
  • 本文介绍了一种图片处理应用,通过固定容器来实现缩略图的功能。该方法可以实现等比例缩略、扩容填充和裁剪等操作。详细的实现步骤和代码示例在正文中给出。 ... [详细]
  • Servlet多用户登录时HttpSession会话信息覆盖问题的解决方案
    本文讨论了在Servlet多用户登录时可能出现的HttpSession会话信息覆盖问题,并提供了解决方案。通过分析JSESSIONID的作用机制和编码方式,我们可以得出每个HttpSession对象都是通过客户端发送的唯一JSESSIONID来识别的,因此无需担心会话信息被覆盖的问题。需要注意的是,本文讨论的是多个客户端级别上的多用户登录,而非同一个浏览器级别上的多用户登录。 ... [详细]
  • Spring框架《一》简介
    Spring框架《一》1.Spring概述1.1简介1.2Spring模板二、IOC容器和Bean1.IOC和DI简介2.三种通过类型获取bean3.给bean的属性赋值3.1依赖 ... [详细]
  • 本文总结了在编写JS代码时,不同浏览器间的兼容性差异,并提供了相应的解决方法。其中包括阻止默认事件的代码示例和猎取兄弟节点的函数。这些方法可以帮助开发者在不同浏览器上实现一致的功能。 ... [详细]
  • 本文整理了常用的CSS属性及用法,包括背景属性、边框属性、尺寸属性、可伸缩框属性、字体属性和文本属性等,方便开发者查阅和使用。 ... [详细]
author-avatar
Sally-__
这个家伙很懒,什么也没留下!
Tags | 热门标签
RankList | 热门文章
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有