前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >P不能包div?

P不能包div?

作者头像
我不是费圆
发布2020-09-22 10:28:08
7860
发布2020-09-22 10:28:08
举报
文章被收录于专栏:鲸鱼动画

P和div同为块元素,为什么P不能做div的父元素?

执行结果:

可以在控制台看到这样一段信息:

div像一条分割线一样,把无辜的 P标签 一分为二

是什么原因导致的呢? W3C这样说:“ 如果你这样做,将会严重违反P的语义 ” 解决方法暂时没有 于是我找到了块级元素和内联元素的嵌套规则,如下:

最基本:内联不能嵌套块级,块级可以嵌套内联元素

< div>< h1>< /h1>< p>< /p>< /div> 正确(块级并列) < a href="#">< span>< /span>< /a> 正确(内联嵌套内联) < span>< div>< /div>< /span> 错误(内联嵌套块级)

有几个特殊的块级元素只能包含内嵌元素,不能再包含块级元素

这几个特殊的标签是:h1、h2、h3、h4、h5、h6、p、dt。所以说p里面不能嵌套div,就是我犯的错误。

< p>< ol>< li>< /li>< /ol>< /p> —— 错 < p>< div>< /div>< /p> —— 错

特殊的< li>里面可以嵌套div(< li>可以但< p>不行)

块级元素与块级元素并列、内联元素与内联元素并列

< div>< h2>< /h2>< p>< /p>< /div>  正确 < div>< a href="#">< /a>< span>< /span>< /div>  正确 < div>< h2>< /h2>< span>< /span>< /div>  错误(块级和内联并列了)

以上是它的嵌套规则,但违反了不一定报错,比如我经常用 a 标签去嵌套 div,我觉得挺好用的。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/09/20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • P和div同为块元素,为什么P不能做div的父元素?
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档