<style>
.tongpian6 {
height: 50px
padding-left: 20px
vertical-align: middle
}
</style>
<table border="1">
<tr>
<td class="tongpian6">hehehe</td>
</tr>
</table>
因为:
1、表格内左边距使用padding-left,而不是margin-left。margin-left叫外左边距。
2、单元格垂直居中,设定vertical-align为middle,而不是bottom(靠下)。
扩展资料:css文本和div垂直居中方法总结
对文本,只需要对其父级元素设置text-align: center,而对div等块级元素,只需要设置其left和right的margin值为auto。
要实现元素的垂直居中,有人会想到css中的vertical-align属性,但是它只对拥有valign特性的元素才生效,例如表格元素中的<td>、<th>、<caption>等,而像<div>、<span>这样的元素是没有valign特性的,因此使用vertical-align对它们不起作用。
1、单行文本垂直居中
对于单行文本,我们只需要将文本行高(line-height)和所在区域高度(height)设为一致即可:
<!--html代码-->
<div id="div1">
这是单行文本垂直居中
</div>
/*css代码*/
#div1{
width: 300px
height: 100px
margin: 50px auto
border: 1px solid red
line-height: 100px/*设置line-height与父级元素的height相等*/
text-align: center/*设置文本水平居中*/
overflow: hidden/*防止内容超出容器或者产生自动换行*/
2、子div垂直居中
<!--html代码-->
<div id="outer">
<div id="middle">
子div(固定大小)垂直居中
</div>
</div>
/*css代码*/
#outer{
background-color: #13CDF4
width: 300px
height: 200px
position: relative
}
#middle{
background-color: #E41627
width: 100px
height: 100px
margin: auto
position: absolute
left: 50%
top: 50%
margin-left: -50px
margin-top: -50px
}
position 的四个属性:static、absolute、relative、fixed
static:默认值
absolute:脱离文档结构,导致父元素坍塌;相对于最近的非static元素进行定位;使得inline元素被“块”化;使得元素已有的float失效。多个悬浮元素,后来者在上方;
relative:根据原来位置,导致自身位置的相对变化,而不会影响其他元素的位置、大小的变化。
产生新的定位上下文,影响子元素(如absolute属性元素定位)
fixed:根据浏览器确定位置
参考文章:https://www.cnblogs.com/wangfupeng1988/p/4322680.html
css原理:
vertical-align :指定行内元素(inline)和行内块级元素(inline-block)或表格单元格(table-cell)元素的垂直对齐方式。
文本垂直居中:
单行文本:设置line-height 和区域高度height 一致即可
多行文本垂直居中:
1、父级元素高度不固定,随内容变化:内填充padding-top = padding-bottom
2、父级元素高度固定:
父元素div:display:table
子元素div:display:table-cell;vertical-align:middle
子div垂直居中:
1、子div具体大小设置偏移
2、利用transform:translateX(-50%)translateY(-50%)
3、利用绝对布局absolute
4、利用vertical-align属性实现子div大小不固定垂直居中
5、利用display:flex:
justify-content: center/*实现水平居中*/
align-items:center/*实现垂直居中*/
参考链接:https://blog.csdn.net/u014607184/article/details/51820508