为什么-webkit-margin-before(以及之后、开始、结束)没有被我的显式边距和填充规则覆盖?

Why is -webkit-margin-before (and after, start, end) not being overridden by my explicit margin and padding rule?(为什么-webkit-margin-before(以及之后、开始、结束)没有被我的显式边距和填充规则覆盖?)

本文介绍了为什么-webkit-margin-before(以及之后、开始、结束)没有被我的显式边距和填充规则覆盖?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有:

html body nav figure {   /* just to clear specificity doubts  */
    margin: 0;
    padding: 0;
    bottom: 0;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    background-color: yellow;
}

我在 chrome 中检查元素,并应用我的规则,但也应用了用户代理样式表中的以下内容:

I inspect element in chrome, and my rules are applied, but also the following from the user agent stylesheet:

figure {
    display: block;
    -webkit-margin-before: 1em;
    -webkit-margin-after: 1em;
    -webkit-margin-start: 40px;
    -webkit-margin-end: 40px;
}

我认为这些应该被覆盖......我的规则也没有被覆盖(没有被划掉)

I thought these should be overridden... my rules are not overridden either (not crossed out)

我应该如何覆盖它们?

推荐答案

我解决了.

应用用户指定的规则,webkit 会根据它呈现边距,以某种方式覆盖"默认的 -webkit 规则.

The rule specified by the user gets applied, and webkit renders margin according to it, "overriding" the default -webkit ones in some way.

我看到的空间是来自未显示为块的 img,请参阅 this 了解更多.

The space that I was seeing was from the img not being displayed as block, see this for more about it.

这篇关于为什么-webkit-margin-before(以及之后、开始、结束)没有被我的显式边距和填充规则覆盖?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本文标题为:为什么-webkit-margin-before(以及之后、开始、结束)没有被我的显式边距和填充规则覆盖?

基础教程推荐