amb*_*use 13 html css css3 zigzag css-shapes
我一直在研究带有锯齿形边框的标题.一种方法是使用图像来制作锯齿形效果.
(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;
}Run Code Online (Sandbox Code Playgroud)
<header>
<br />
<br />
<br />
<br />
</header>
<img src="http://i.imgur.com/qKsVr.png" />Run Code Online (Sandbox Code Playgroud)
编辑#1:
谢谢Ana的代码.我接受了它并对其进行了改进.
http://dabblet.com/gist/3401493
我不认为一致的背景是可能的.
Ana*_*Ana 19
如果您打算使用border-image,那么它不是跨浏览器解决方案,因为IE不支持它.
此外,即使除IE9之外的每个当前浏览器版本都支持CSS渐变(这将允许您获得Z字形图案),并且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;
Run Code Online (Sandbox Code Playgroud)
如果你想要一个低于此的纹理与这个纹理同步,那么你必须确保它以相同的间隔重复(40px但你也可以去20px).
编辑:关于polyfills,你可以尝试列出的其中一个位置:CSS3 PIE或cssSandpaper
(在现代浏览器中)您可以使用SVG创建简单的绘图,并将它们用作嵌入为数据URI的 CSS背景图像.
以下是SVG的外观:
body {
background: #888;
}Run Code Online (Sandbox Code Playgroud)
<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>Run Code Online (Sandbox Code Playgroud)
例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");
}Run Code Online (Sandbox Code Playgroud)
<div class="zigzag-outside">Example 1</div>Run Code Online (Sandbox Code Playgroud)
例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");
}Run Code Online (Sandbox Code Playgroud)
<div class="zigzag-inside"></div>Run Code Online (Sandbox Code Playgroud)
改进了最小 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;
}Run Code Online (Sandbox Code Playgroud)
<div>
<h1>Zig Zag Borders</h1>
</div>Run Code Online (Sandbox Code Playgroud)
如果您想删除重复值,您可以使用CSS 变量(又名自定义属性)。除了 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;
}Run Code Online (Sandbox Code Playgroud)
<div>
<h1>Zig Zag Borders</h1>
</div>Run Code Online (Sandbox Code Playgroud)
我0在渐变色标中使用零以避免重复以前的值,因为根据CSS3 图像规范,色标位置不能小于前一个。
如果某个色标的位置小于列表中该色标之前的任何色标的指定位置,则将其位置设置为等于它之前的任何色标的最大指定位置。