css - 如何给html节点内的第一个子节点定义样式
问题描述
文档结构如下
- <article> |- <h1> or <h2> or <p> or ... # 第一个子节点,出现内容不确定 |- <h1> or <h2> or <p> or ... # 第二个子节点,不受第一个影响 |- <h1> or <h2> or <p> or ... # 同上
如上面的代码所示,由于 h1, h2, p 这些具有不同的 margin-top,我想将紧跟着的这些元素的 margin-top 都重置为 0,但同时不影响后面出现的这些 tag,应该用什么方法?
更新:附上使用 first-child 后的效果:http://jsfiddle.net/Ygdfc/1/
问题解答
回答1:如果使用 css3 的话,可以用:
/* 选择第一个子元素 */article h1:first-child{ margin-top:0;}
鉴于某知名浏览器(我也不知道哪个浏览器,呵呵)对 CSS3 不够支持,可以使用大名鼎鼎的 jquery 来解决。
$('article h1:first-child').css('margin-top',0);回答2:
CSS2 也支持第一个子节点的选择符:
article > h1, article > h2, article p { /* CSS here */}
参考:
http://www.w3.org/TR/CSS2/selector.html#child-selectors
相关文章:
1. javascript - 一排三个框,各个框的间距是15px,距离外面的白框间距也是15px,这个css怎么写?2. javascript - Vue 的依赖追踪属于单向数据绑定还是双向绑定?3. html5 - javascript写业务有用到什么编程范式没?4. javascript - vue 数据更新了。但是dom没有更新,,,,,如图5. javascript - jQuery post()方法,里面的请求串可以转换为GBK编码么?可以的话怎样转换?6. javascript - vue 手机端项目在进入主页后 在进入子页面,直接按返回出现空白情况7. 网页爬虫 - python爬虫翻页问题,请问各位大神我这段代码怎样翻页,还有价格要登陆后才能看到,应该怎么解决8. html5 - vue-cli 装好了 新建项目的好了,找不到项目是怎么回事?9. mysql - C#连接数据库时一直这一句出问题int i = cmd.ExecuteNonQuery();10. javascript - 哪位大神指导下,如何实现今日头条头部导航列表,点那个类型,哪种类型就居中了?

网公网安备