CSS渐变用于三角箭头形状的箭头

10
请查看http://jsfiddle.net/ghAgQ/,我需要箭头和矩形应用相同的渐变。有什么想法如何实现?谢谢。
.rectangle {
background-color: #EEE;
height: 80px;
width: 240px;
border: 1px solid #CCC;
background: white;
cursor: pointer;
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,white),             color-stop(37%,#F1F1F1), color-stop(57%,#E1E1E1), color-stop(100%,#F6F6F6));
float: left;
}

.arrow {

border-top: 41px solid transparent;
border-bottom: 41px solid transparent;
border-left: 15px solid #C4C4C4;
float: left;
cursor: pointer;

}


3
请在您的问题中始终包含相关代码。外部链接很好,但如果它们被删除,您的问题仍应对他人有用。 - James Montagne
2个回答

34

可以使用一个元素和旋转的伪元素(任何支持 CSS 渐变的浏览器也支持 CSS 变形伪元素),以及一个倾斜的线性渐变,以更简单的方式来实现此目的。另外,请不要使用旧版 WebKit 语法(有关语法历史的信息请参见此部分)。

在当前版本的 Chrome、Opera、Firefox 和 IE 上可以正常工作。

演示

HTML 只是 <div class='rectangle'></div>

相关 CSS

.rectangle {
    float: left;
    position: relative;
    height: 80px;
    width: 240px;
    border: solid 1px #ccc;
    border-right: none;
    background: #eee linear-gradient(white, #f1f1f1 37%, #e1e1e1 57%, #f6f6f6);
    cursor: pointer;
}
.rectangle:after {
    position: absolute;
    top: 16px; right: -25px;
    width: 48px;
    height: 47px;
    border-left: solid 1px #ccc;
    border-top: solid 1px #ccc;
    transform: rotate(134deg) skewX(-10deg) skewY(-10deg);
    background: #eee linear-gradient(45deg, white, #f1f1f1 37%, #e1e1e1 57%, #f6f6f6);
    content: '';
}

2013年1月更新

4个月后,我有了一个稍微改进的解决方案。这次,值是计算出来的。第一次我是用试错法得到的。

新演示

.shape {
    float: left;
    position: relative;
    border: 1px solid #ccc;
    border-right: none;
    width: 240px; height: 80px;
    background: linear-gradient(white, #f1f1f1 37%, #e1e1e1 57%, #f6f6f6);
    cursor: pointer;
}
.shape:after {
    position: absolute;
    top: 50%; right: 0;
    margin: -24px -20px;
    border-top: solid 1px #ccc;
    border-right: solid 1px #ccc;
    width: 40px /* 80px/2 */; height: 47px/* 80px/sqrt(3) */;
    transform: rotate(30deg) skewY(30deg); /* create a rhombus */
    /* 49.1deg = atan(1.15) = atan(47px/40px) */
    background: 
            linear-gradient(-49.1deg, #f6f6f6, #e1e1e1 43%, #f1f1f1 63%, white);
    content: ''
}
<div class='shape'></div>


相当不错,但并非完美的解决方案。您可以看到箭头顶点的边框厚度不均匀。 - weexpectedTHIS
这很棒,是个好的解决方案,但目前不能在最新的Chrome版本28.0.1500.95上正常工作。 - user979051
什么操作系统?在我这里,它在Windows 7上的Chrome浏览器(版本28.0.1500.95 m)中运行良好。 - Ana
我已经构建了一个更跨浏览器的解决方案,请见下文。 - Roland Schütz
@Ana,我们能否使其响应式,例如根据可用宽度和高度将宽度和高度设置为百分比,以便它可以扩展? - atif
非常有帮助的答案!稍微尝试一下,可能会帮助您使用自己的参数(颜色、宽度/高度、渐变本身)创建箭头。非常感谢! - Klimenko Kirill

0

虽然上面的演示在Chrome中看起来非常好,但缺少任何浏览器支持信息,并且在许多浏览器中无法正常工作。我花了一些时间开发了一种更跨浏览器的方法。

这里有一个解决方案,适用于所有现代浏览器,使用SASS构建函数非常不错

.triangle {
    /* sample positioning */
    width: 160px;
    height: 160px;
    position: absolute;
    top: 30%;
    left: 45%;

    /*
     * deprecated syntax has better browser support
     * IE8+
     * http://css-tricks.com/almanac/properties/c/clip/
     */
    clip: rect(auto, 180px, auto, 100px);

    -webkit-transform: rotate(-90deg);
    -moz-transform: rotate(-90deg);
    -o-transform: rotate(-90deg);
    transform: rotate(-90deg);
}

.triangle::after {
    content: "";
    position: absolute;
    top: 10px;
    bottom: 10px;
    left: 10px;
    right: 10px;

    /**
     * To also support IE 9 we you a background images
     * as fallback, created via compass:
     * @include background-image(linear-gradient(300deg, green, blue));
     */
    background-image: url('');
    background-size: 100%;
    background-image: -moz-linear-gradient(150deg, green, blue);
    background-image: -webkit-linear-gradient(150deg, green, blue);
    background-image: linear-gradient(300deg, green, blue);


    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

目前支持IE 10+,Firefox,Opera,Chroma,Safari


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接