- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们有一个包含三个列表项的简单列表。 JSFiddle .
第一个 li 背景属性设置为:
background: url(http://url-here.png) no-repeat 0 50% / 15px 15px;
设置了no-repeat,但是省略了background-clip。
第二个 li 的背景中同时设置了无重复和边框框:
background: url(http://url-here.png) no-repeat 0 50% / 15px 15px border-box;
和第三里类似于第一里,但背景剪辑手动设置:
background: url(http://url-here.png) no-repeat 0 50% / 15px 15px;
background-clip: border-box;
请记住,background-clip 的默认值为“border-box”,我假设为第二个和第三个 li 设置值是多余的,但只有第二个 li 会显示背景图像。
在 Opera v. 37.0.2178.54 和 Google Chrome v. 50.0.2661.102 m 中测试
请帮我弄清楚它的工作方式。谢谢!
最佳答案
没有 background-repeat
不会以任何方式影响 background-clip
属性。您在第二个 li
中看到的差异是由于不同的原因造成的。在简写属性中,当我们只提供一个 box
值时,background-clip
和 background-origin
都获得相同的值。
来自W3C Spec :
If one value is present then it sets both ‘background-origin’ and ‘background-clip’ to that value.
因此,您的第二个 li
获得 background-origin: border-box
而对于其他两个,它被设置为 default value which is padding-box
.
background-origin
是指定 background
应该从哪里开始的属性。由于第一个和第三个 li
将 background-origin
设置为 padding-box
,因此它们的背景设置在 padding box 区域内(在边框)。
如果为所有三个 li
设置相同的 background-origin
那么它们将以相同的方式显示,而不管 background-repeat
设置如何。
ul {
list-style-type: none;
}
li {
border: 10px solid rgba(0, 0, 0, 0.60);
padding-left: 20px;
margin-bottom: 10px;
}
.no-repeat {
background: url(http://postcrossing-ua.com/static/pybb/smiles/D83DDE03.png) no-repeat 0 50% / 15px 15px;
background-origin: border-box;
}
.no-repeat-border-box {
background: url(http://postcrossing-ua.com/static/pybb/smiles/D83DDE03.png) no-repeat 0 50% / 15px 15px border-box;
}
.border-box {
background-clip: border-box;
background-origin: border-box;
}
<ul>
<li class="no-repeat">White</li>
<li class="no-repeat-border-box">Black</li>
<li class="no-repeat border-box">Red</li>
</ul>
关于css - background no-repeat 将 background-clip 属性设置为 padding-box?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37663126/
String 有 PadLeft 和 PadRight。我需要左右填充(居中对齐)。是否有执行此操作的标准化方法,或者更好的是,是否有实现相同目标的内置方法? 最佳答案 据我所知没有。如果您发现自己经
我刚开始学习 CSS,所以我的问题很基础。如图,如果设置padding:10px;的,但在结果中,似乎只有顶部和左侧工作,为什么会这样,我的意思是如果使用工作流程,它应该是最后两个底部和左侧工作吗?
我正在尝试重新创建类似于 this 的内容.我注意到输入字段不能在 内因为那样他们会得到难看的填充物。另一方面,按钮需要此填充,否则它会粘在没有任何填充的一侧。 以下代码不起作用,因为它将按钮放置在
我正在尝试将以下 Keras 模型代码转换为 pytorch,但在处理 padding='same' 时遇到问题。 model = Sequential() model.add(Con
与主题中的问题相同,有时是否可以将 pad 从例如 decodebin 元素链接到其他兼容元素的 pad? 我正在尝试做这样的事情: GstElement *decodebin = gst_eleme
尝试使用相同的数据集依次评估一堆 transformers 模型,以检查哪个模型表现更好。 模型列表是这个: MODELS = [ ('xlm-mlm-enfr-1024' ,"XLM
尝试使用相同的数据集依次评估一堆 transformers 模型,以检查哪个模型表现更好。 模型列表是这个: MODELS = [ ('xlm-mlm-enfr-1024' ,"XLM
根据 http://www.maxdesign.com.au/articles/inline/ ,名为“内联元素和填充”的部分说 While padding can be applied to all
在 的左侧和右侧有 3px 的填充标记导致顶部和底部填充。请参阅此处的示例...(但是对于这个 jsfiddle,我只复制了底部的填充,而不是顶部的填充)。 #xyz { padding-r
我有一个滚动时间线 ( demo ),我遇到了 padding-left 在滚动之前隐藏时间线左侧的时间线分支图像的问题, 但 padding-right 无法隐藏右侧的分支图像。 我尝试使用的方法是
我不想用这个来骚扰你,但我在互联网上的任何地方都找不到对“位填充”到底是什么的详细解释,也没有找到与位填充相关的线程的任何答案在 StackOverflow 上。 我还在 ISO 9899-1990
在检查一些代码时,我发现了这个新声明:-webkit-padding-start 但我无法理解与现有的 padding-left 有什么区别属性(property)。我已经阅读了 Mozilla De
这是我的CSS: body { margin: 0px; background-color: white; } #navbar { background-color: red; margin: 0 a
所以我试图获得一些带有填充的文本修饰符,在我导入 androidx.compose.foundation.layout.padding 之前一切都很好以及 Modifier.padding(10.dp
我正在尝试使用 Python 的 base64.b64decode(str) 方法对字符串进行 Base64 解码(转换为字节): 46oWrWpy2gTEGwNnN6Ayy 并且我确保它有 4 个
两台不同的计算机(相同的 python 版本)为 time.ctime() 返回不同的格式。一个返回 "Sun May 6 14:04:28 2018" 月份前有2个空格;其他返回 "Sun May
代码中没有设置右边距或右边距的地方,当在 Chrome 的开发者工具中查看表单元素时,它在样式列表中同时显示“padding: 0”和“margin: 0”,但是 确实将鼠标悬停在表单元素上时显示边距
有没有办法在 Flexbox 中将 padding-left 和 padding-right 设置为元素宽度的 10%。我尝试使用 padding: 0 10%;,但它不是元素宽度的 10%。 .fl
image codepen 你好,我需要 CSS 样式方面的帮助。 我正在尝试有一个响应式主菜单,但无法想出一种方法来保持文本在元素框中水平居中,一旦这些由于视口(viewport)宽度较低而开始缩小
androidx.compose.material3.Scaffold 填充错误地添加了导航栏填充,即使在打开软键盘时添加了 IME 填充,导致导航栏填充量加倍(请参见下面的屏幕截图,分隔线应该接触到
我是一名优秀的程序员,十分优秀!