CSS之字形边界有织地不很细背景

时间:2012-08-20 01:23:42

标签: html css css3 css-shapes zigzag

我一直在研究带有曲折边框的标题。一种方法是使用图像来产生锯齿效果。

(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:

感谢Ana的代码。我接受了它并对其进行了改进。

http://dabblet.com/gist/3401493

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

3 个答案:

答案 0 :(得分:19)

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

此外,即使除IE9之外的每个当前浏览器版本都支持CSS渐变(这将允许您获得a zig-zag pattern)和border-image,上次我检查(这是几个月前,所以最好再次测试一下),使用border-image的渐变仅在WebKit中工作。另外,我不认为即使在WebKit中也可以使用多个渐变(因为您只能设置一个边框图像,一个渐变是一个图像),并且需要两个渐变用于Z字形图案。

CSS zig-zag模式的代码是:

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)。


修改:关于polyfills,您可以尝试其中一个hereCSS3 PIEcssSandpaper

答案 1 :(得分:7)

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

这是SVG的样子:

&#13;
&#13;
body {
  background: #888;
}
&#13;
<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>
&#13;
&#13;
&#13;

示例1:

&#13;
&#13;
.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");
}
&#13;
<div class="zigzag-outside">Example 1</div>
&#13;
&#13;
&#13;

示例2:

&#13;
&#13;
.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");
}
&#13;
<div class="zigzag-inside"></div>
&#13;
&#13;
&#13;

答案 2 :(得分:2)

改进了最小的CSS:

div {
  background: #1ba1e2;
  position: relative;
}

div:after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 30px;
  background: linear-gradient(-45deg, transparent 75%, #1ba1e2 0) 0 50%,
              linear-gradient(45deg, transparent 75%, #1ba1e2 0) 0 50%;
  background-size: 30px 30px;
}

/* Styles just for demo */
h1 {
  color: #fff;
  text-align: center;
  margin: 0;
  padding: 0.5em;
}
<div>
  <h1>Zig Zag Borders</h1>
</div>

如果要删除重复值,可以使用CSS variables AKA Custom properties。除IE之外,他们到处工作。

:root {
  --background-color: #1ba1e2;
  --zigzag-item-size: 30px;
}

div {
  background: var(--background-color);
  position: relative;
}

div:after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: var(--zigzag-item-size);
  background: linear-gradient(-45deg, transparent 75%, var(--background-color) 0) 0 50%,
              linear-gradient(45deg, transparent 75%, var(--background-color) 0) 0 50%;
  background-size: var(--zigzag-item-size) var(--zigzag-item-size);
}

/* Styles just for demo */
h1 {
  color: #fff;
  text-align: center;
  margin: 0;
  padding: 0.5em;
}
<div>
  <h1>Zig Zag Borders</h1>
</div>

小记:

我在渐变颜色停止中使用零0以避免重复先前的值,因为根据CSS3 images specs颜色停止位置不能小于前一个颜色。

  

如果颜色停止的位置小于列表中任何颜色停止位置的指定位置,请将其位置设置为等于之前任何颜色停止位置的最大指定位置。