制作一个带有圆角边的3D按钮。

3

我正在开发一个网站,想要实现带圆角的3D按钮。因此,我需要创建一个CSS文件。我搜索了很多关于3D按钮的资料,但目前为止还没有找到合适的解决方案。

4个回答

6
您想使用以下css样式的组合:border, border-radius, background, text-shadowbox-shadow。要使用这些样式实现3D效果,需要在background样式上使用gradient值。
有一个有用的工具可以制作跨浏览器渐变css,链接在这里:http://www.colorzilla.com/gradient-editor/ 下面是一些示例CSS,可以为a标签设置样式:
.button {
    display: block;
    height: 30px;
    margin-bottom: 10px;
    text-align: center;
    line-height: 30px;
    width: 150px;
    margin: 20px;

    color: #FFF;
    text-align: center;
    border: solid #427AA8 1px;
    border-radius: 5px;
    text-decoration: none;

    /* Gradient */
    background: #427AA8;
    background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/Pgo8c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjAlIiB5MT0iMCUiIHgyPSIwJSIgeTI9IjEwMCUiPgogICAgPHN0b3Agb2Zmc2V0PSIxJSIgc3RvcC1jb2xvcj0iIzU5YTNlMCIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiM0MjdhYTgiIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGllbnQ+CiAgPHJlY3QgeD0iMCIgeT0iMCIgd2lkdGg9IjEiIGhlaWdodD0iMSIgZmlsbD0idXJsKCNncmFkLXVjZ2ctZ2VuZXJhdGVkKSIgLz4KPC9zdmc+);
    background: -moz-linear-gradient(top,  #59A3E0 1%, #427AA8 100%);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(1%,#59A3E0), color-stop(100%,#427AA8));
    background: -webkit-linear-gradient(top,  #59A3E0 1%,#427AA8 100%);
    background: -o-linear-gradient(top,  #59A3E0 1%,#427AA8 100%);
    background: -ms-linear-gradient(top,  #59A3E0 1%,#427AA8 100%);
    background: linear-gradient(to bottom,  #59A3E0 1%,#427AA8 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#59A3E0', endColorstr='#427AA8',GradientType=0 );

    text-shadow: 1px 1px 0 rgba(0,0,0,0.25);
    box-shadow: 0 1px 0 rgba(255,255,255, 0.3), inset 0 1px 0 rgba(255,255,255, 0.3);
}

.button:hover {
    background: #59A3E0;
    text-decoration: none;
    filter: none;
}​

<a href="#" class="button">Example Button</a>

以下是您可以制作的示例:jsfiddle.net/UPTyw

此方法在所有现代浏览器上都可以很好地工作,并且在不支持border-radius的IE8-6上也可以正常运行。此方法还不使用任何图像。

此外,请查看这个问题:Google的无图像按钮,其中讲解了Google如何创建其系列CSS按钮。

IE9 Bug

如果设置了filter,则IE9存在渲染border-radius的错误。解决方法是为使用css渐变的任何元素添加以下仅限IE9的CSS

<!--[if gte IE 9]>
  <style type="text/css">
    .gradient {
       filter: none;
    }
  </style>
<![endif]-->

4

1
那个网站和生成的按钮在Opera浏览器中无法正常工作。但是,如果你通过http://prefixr.com/运行生成的CSS代码,它应该可以正常工作。 - Ignitor

0

0
<style>
button {
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
}
</style>

<button>Test</button>

请参见:http://jsfiddle.net/wPcn3/


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