我正在谷歌Chrome浏览器上做一个网页。它以以下样式正确显示。

table {
    display: table;
    border-collapse: separate;
    border-spacing: 2px;
    border-color: gray;
}

需要注意的是,我没有定义这些样式。在Chrome开发工具中,它说用户代理样式表代替CSS文件名。

现在,如果我提交了一个表单,出现了一些验证错误,我会得到以下样式表:

table {
    white-space: normal;
    line-height: normal;
    font-weight: normal;
    font-size: medium;
    font-variant: normal;
    font-style: normal;
    color: -webkit-text;
    text-align: -webkit-auto;
}

table {
    display: table;
    border-collapse: separate;
    border-spacing: 2px;
    border-color: gray;
}

这些新样式的字体大小影响了我的设计。有没有办法强制我的样式表,如果可能的话,完全覆盖Chrome的默认样式表?


当前回答

在CSS文件中放入以下代码:

table {
    font-size: inherit;
}

其他回答

在你自己的CSS内容中定义你不想从Chrome的用户代理样式中使用的值。

一些浏览器使用自己的方式读取.css文件。 所以正确的解决方法是: 如果您直接在.html源代码中键入命令行,这将击败.css文件,以这种方式,您直接告诉浏览器要做什么,并且浏览器处于不从.css文件读取命令的位置。 请记住,写在.html文件中的命令比写在.css文件中的命令更强大。

如果< !DOCTYPE>在您的HTML内容中缺失,您可能会遇到浏览器优先选择“用户代理样式表”而不是自定义样式表。添加文档类型可以解决这个问题。

我也遇到了同样的问题,这是因为我正在使用非语义html

<!--incorrect-->
<ul class="my-custom-font">
  <button>
    <a>user agent styles applied instead of my-custom-font</a>
  <button>
</ul>

<!--correct-->
<ul class="my-custom-font">
  <li>
    <a>now inherits from from my-custom-font</a>
  </li>
</ul>

一旦更新了HTML,就正确地应用了样式

在CSS文件中放入以下代码:

table {
    font-size: inherit;
}