0

0

CSS进阶之CSS的技巧分享

高洛峰

高洛峰

发布时间:2017-03-23 11:28:42

|

1315人浏览过

|

来源于php中文网

原创

如何设置水平居中?

分两种情况 行内元素与块级元素

    1.行内元素(如图片 文字)

   div.textcenter{
   text-align:center;
   }
   
hello joe!

    2.块级元素

    块级元素的水平居中又分为两种 定宽块状元素 和 非定宽块状元素

立即学习前端免费学习笔记(深入)”;

    

    定宽块状元素(即块状元素的width值是定值):

    可以通过块级元素的左右margin为auto来实现中 如下

   div{
   border:1px solid red;
   width:500px;/*定宽*/
   margin:30px auto;/*margin-right margin-left为auto*/
   }
   
I am middle placed.

    不定宽块状元素(即宽度width不确定 比如网页上的分页导航)

    对于不定宽元素实现水平居中有三种方法(常用):

    第一种方法:利用table标签

    利用table标签的长度自适应性---即不定义其长度也不默认父元素body的长度(table其长度根据其     内文本长度决定),因此可以看做一个定宽度块元素,然后再利用定宽度块状居中的margin的方       法,使其水平居中

第一步:为需要设置的居中的元素外面加入一个 table 标签 ( 包括

、、 )。

第二步:为这个 table 设置“左右 margin 居中”(这个和定宽块状元素的方法一样)。

   table{
   margin: 0 auto;
   }
   ul{list-style:none;/*将小圆点去掉*/}
   li{float:left;display:inline;margin-right:5px;}
   

 第二种方法:改变块级元素的 display 为 inline 类型(设置为 行内元素 显示),然后使用 text-align:center 来实现居中效果。如下例子:

   .container{
   text-align:center;
   }
   .container ul{
   display:inine;
   list-style:none;
   padding:0;
   margin:0;
   }
   .container li{
   display:inline;
   margin-right:8px;
   }

    与第一种方法相比不用添加无语义标签(table)但是由于li被视作行内元素,所以无法为其设定height,width等属性

    第三种方法:通过给父元素设置 float,然后给父元素设置 position:relative 和 left:50%,子元素设置 position:relative 和 left: -50% 来实现水平居中。

   .container{
   float:left;
   position:relative;
   left:50%;
   }
   .container ul{
   list-style:none;
   margin:0;
   padding:0;
   position:relative;
   left:-50%;
   }
   .container li{
   float:left;
   display:inline;
   margin-right:8px;
   }
   

2.如何设置垂直居中?

YIXUNCMS中秋专版2.0.4
YIXUNCMS中秋专版2.0.4

系统介绍:YIXUNCMS中专专版是易迅软件工作室在中秋节来临之即推出的专题模板建站系统,使用增强版后台管控系统,板板设计符合节日特点。易迅软件工作室恭祝全国人民中秋快乐。特别提示:由于网站页面的不同设计,部分后台功能未在前端进行体现。系统特点:1、采用目前流行的PHP语言编写,底层采用超轻量级框架作为系统支撑;2、页面布局使用DIV+CSS技术,遵循WEB标准,及大提高页面的浏览速度;3、使用应

下载

分为两种情况,父元素高度确定的单行文本,父元素高度确定的多行文本。

单行文本:通过设置line-height 与 height一致实现垂直居中

line-height 与 font-size 的计算值之差,在 CSS 中成为“行间距”。分为两半,分别加到一个文本行内容的顶部和底部。

这种文字行高与块高一致带来了一个弊端:当文字内容的长度大于块的宽时,就有内容脱离了块。

.container{
    line-height:100px;
    height:100px;
    background:purple;
}

Hello World!

CSS进阶之CSS的技巧分享

但是该方法有一个弊端:当文字的长度长于块的宽度的时候,内容就脱离了块。

多行文本:

有两种方法:

使用table标签 使用vertical-align:middle(注意td标签默认就设置了vertical-align:middle

所以不需要我们手动设置。

table td{
height:500px;
background:#purple;
}
I am centered
I am centered
I am centered
I am centered
I am centered

CSS进阶之CSS的技巧分享

最后一个技巧

隐式的改变display的属性 当为元素设置以下两个语句之一的话:

float:right 或者float:right

position:absolute

元素的display类型就会自动变为display:inline-block 此时就可以设置元素的宽和高了例如



    

CSS进阶之CSS的技巧分享

相关专题

更多
高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

4

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

3

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

10

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

33

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

15

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

42

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

7

2026.01.15

ps图片相关教程汇总
ps图片相关教程汇总

本专题整合了ps图片设置相关教程合集,阅读专题下面的文章了解更多详细内容。

9

2026.01.15

ppt一键生成相关合集
ppt一键生成相关合集

本专题整合了ppt一键生成相关教程汇总,阅读专题下面的的文章了解更多详细内容。

6

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 19.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号