css中 第一个子元素节点的 margin-top 会作用到父元素上,加了 文字 (文字属于文本节点) div 就不是第一个子元素节点了或者给父元素加overflow。
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<title></title>
<style>
.a{width: 400px;height: 400px;background-color: skyblue;overflow: hidden;}
.b{width: 300px;height: 300px;background-color: pink;margin: 20px auto;}
</style>
</head>
<body>
<div class="a">
<div class="b"></div>
</div>
</body>
</html>