带纹理背景的 CSS 之字形边框

新手上路,请多包涵

我一直在研究带有锯齿形边框的页眉。一种方法是使用图像来制作之字形效果。

(1) 有没有办法在不使用图像的情况下在 CSS 中创建实用的跨浏览器之字形边框?

我还试图在延伸到之字形的标题上放置带纹理的背景。但是,标题的垂直大小可能会改变,我无法将标题实现为单个图像。

如果我尝试向之字形边缘和标题元素添加纹理,很可能纹理将不同步。

(2) 关于实现延伸到之字形而不不同步的纹理背景有什么想法吗?

我的 [旧] 代码(连同纹理)在 jsFiddle 上。

 body {
  padding: 20px;
}

header {
  width: 240px;
  background-color: #BCED91;
}

header:after {
  content: " ";
  display: block;
  position: relative;
  width: 240px;
  bottom: -15px;
  height: 15px;
  background: url() repeat-x;
}

img {
  margin-top: 50px;
}
 <header>
  <br />
  <br />
  <br />
  <br />
</header>

<img src="http://i.imgur.com/qKsVr.png" />

编辑#1:

谢谢安娜的代码。我接受并改进了它。

http://dabblet.com/gist/3401493

我不认为一致的背景是可能的。

原文由 ambiguousmouse 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 483
2 个回答

如果您打算使用 border-image ,那么它不是跨浏览器解决方案,因为 IE 不支持它。

此外,尽管除 IE9 之外的每个当前浏览器版本都支持 CSS 渐变(这将允许您获得 锯齿形图案)和 border-image ,但我上次检查时(这是几个月前的事了,所以最好再测试一次),使用渐变 border-image 只在 WebKit 中有效。另外,我认为即使在 WebKit 中也不能使用多个渐变(因为您只能设置一个边框图像,一个渐变是一个图像)并且您需要两个渐变来实现之字形图案。

CSS之字形图案的代码是:

 background: linear-gradient(#BCED91 49%, transparent 49%),
        linear-gradient(-45deg, white 33%, transparent 33%) 0 50%,
        white linear-gradient(45deg, white 33%, #BCED91 33%) 0 50%;
    background-repeat: repeat-x;
    background-size: 1px 100%, 40px 40px, 40px 40px;

如果你想要下面的纹理与这个同步,那么你必须确保它以相同的间隔重复( 40px ,但你也可以选择 20px ) .


编辑:关于 polyfill,您可以尝试 此处 列出的其中一种: CSS3 PIEcssSandpaper

原文由 Ana 发布,翻译遵循 CC BY-SA 3.0 许可协议

(在现代浏览器中)您可以使用 SVG 来创建简单的绘图,并将它们用作作为 数据 URI 嵌入的 CSS 背景图像。

这是 SVG 的样子:

 body {
  background: #888;
}
 <svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="8px" height="4px">
  <polygon points="0,4 4,0 8,4" fill="#CC0000" />
</svg>
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="8px" height="4px">
  <polygon points="0,0 4,4 8,0" fill="#CC0000" />
</svg>
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="8px" height="4px">
  <polygon points="0,0 4,4 8,0" fill="#FFFFFF" />
</svg>
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="8px" height="4px">
  <polygon points="0,4 4,0 8,4" fill="#FFFFFF" />
</svg>

示例 1:

 .zigzag-outside {
  position: relative;
  margin-top: 4px;
  margin-bottom: 4px;
  background-color: #CC0000;
  /* example content */
  padding: 1em;
  font: bold medium sans-serif;
  color: #FFFFFF;
}
.zigzag-outside:before {
  content: "";
  position: absolute;
  top: -4px;
  left: 0;
  right: 0;
  height: 4px;
  /* red up pointing triangle */
  background-image: url("data:image/svg+xml,%3Csvg%20version%3D%221.1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%228px%22%20height%3D%224px%22%3E%3Cpolygon%20points%3D%220%2C4%204%2C0%208%2C4%22%20fill%3D%22%23CC0000%22%2F%3E%3C%2Fsvg%3E");
}
.zigzag-outside:after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  right: 0;
  height: 4px;
  /* red down pointing triangle */
  background-image: url("data:image/svg+xml,%3Csvg%20version%3D%221.1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%228px%22%20height%3D%224px%22%3E%3Cpolygon%20points%3D%220%2C0%204%2C4%208%2C0%22%20fill%3D%22%23CC0000%22%2F%3E%3C%2Fsvg%3E");
}
 <div class="zigzag-outside">Example 1</div>

示例 2:

 .zigzag-inside {
  position: relative;
  /* example content */
  width: 600px;
  height: 100px;
  background-image: url(http://i.stack.imgur.com/uOVfl.jpg);
}
.zigzag-inside:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  /* white down pointing triangle */
  background-image: url("data:image/svg+xml,%3Csvg%20version%3D%221.1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%228px%22%20height%3D%224px%22%3E%3Cpolygon%20points%3D%220%2C0%204%2C4%208%2C0%22%20fill%3D%22%23FFFFFF%22%2F%3E%3C%2Fsvg%3E");
}
.zigzag-inside:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 4px;
  /* white up pointing triangle */
  background-image: url("data:image/svg+xml,%3Csvg%20version%3D%221.1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%228px%22%20height%3D%224px%22%3E%3Cpolygon%20points%3D%220%2C4%204%2C0%208%2C4%22%20fill%3D%22%23FFFFFF%22%2F%3E%3C%2Fsvg%3E");
}
 <div class="zigzag-inside"></div>

原文由 Salman A 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
logo
Stack Overflow 翻译
子站问答
访问
宣传栏