8

是否可以仅使用 HTML 和 CSS 创建下面的弯曲帆形状?

帆形

我可以从这个答案中看到,我可以使用以下方法创建一个直边帆:

#triangle {
    width: 0;
    height: 0;
    border-right: 50px solid transparent;
    border-bottom: 100px solid red;
}

看起来像:

直边帆

或者我可以更接近边界半径:

#sail {
    background: #ff0000;
    width: 50px;
    height: 100px;
    border-top-right-radius: 50px 100px;
    -moz-border-radius-topright: 50px 100px;
    -webkit-border-top-right-radius: 50px 100px;
    -khtml-border-radius-topright: 50px 100px;
}

看起来像这样:

弯曲的帆形

但并不像我想要的那样优雅。顶部的帆图像具有柔和优雅的曲线。

不使用图像我可以做得更好吗?

4

2 回答 2

3

我试试我自己可能是你想要的。

.sail{
    width: 50px;
    height: 100px;
    position:relative;
    overflow:hidden;
}
.sail:after{
    width:200px;
    height:200px;
    content:'';
    position:absolute;
    right:0;
    top:-5px;
    -moz-border-radius:100px;
    border-radius:100px;
    background: #ff0000;
}

检查这个http://jsfiddle.net/wtENa/

于 2012-04-05T09:19:46.333 回答
0

我们可以radial-gradient()用来绘制这个形状:

div {
  background: radial-gradient(200px at -50px 100%, red 50%, transparent 50%);
}

div {
  background: radial-gradient(200px at -50px 100%, red 50%, transparent 50%);
  height: 100px;
  width: 50px;
}
<div>

</div>

于 2016-12-23T15:24:23.427 回答