1

我正在开发一个外观有光泽的按钮。按钮可以有各种颜色和大小。这是我到目前为止所做的:

.btn-zen-inverse, .btn-zen-inverse:hover{
    color: white;
    background: 
    url("../img/btn_right.png") no-repeat right 0,
    url("../img/btn_left.png") no-repeat  left 0,
    url("../img/btn_center.png") repeat-x 42px 0;
  background-color: #273032;
  background-size: contain; 
  line-height: 50px;
  margin: 12px 18px 3px 0;
  padding: 0;
  border: 2px solid white !important;
}

引用的图像是 alpha 透明的。这个想法是根据背景颜色属性设置颜色。该图像还有一些其他属性,但这些只是审美。

这 ofcorse 渲染的图像看起来像这样!我希望中心图像仅在图像的中心部分可见。正如你从我的css中看到的那样。这只需要在四大浏览器的最新版本中正常工作。

在此处输入图像描述

这就是我希望它看起来的样子:

在此处输入图像描述

一种建议是使用背景渐变来执行此操作。如果可能的话,我需要按照填充/边距的工作方式来定义背景位置。那可能吗?

设计包含:2 个边框:一个白色一个渐变,一个背景渐变。顶部有一个 1px 厚的垂直渐变。

4

2 回答 2

2

这是我只能用 CSS 得到的最接近的结果。

请注意,IE8 不支持多背景。以下代码也不是,但至少您不需要图像。

按钮预览

现场演示

HTML:

<a class="button dark" href="#"><span>Prova Zenconomy Gratis</span></a>

CSS:

.button {
    display:inline-block;
    border:2px solid;
    -webkit-border-radius:5px;
    -moz-border-radius:5px;
    border-radius:5px;
    line-height:40px;
    text-decoration:none;
    font-family:Helvetica,Arial,sans-serif;
    -webkit-box-shadow: 0 0 4px 1px rgba(204, 204, 204, 0.7);
    -moz-box-shadow: 0 0 4px 1px rgba(204, 204, 204, 0.7);
    box-shadow: 0 0 4px 1px rgba(204, 204, 204, 0.7);
}
.button > span {
    padding:0 40px;
    display:block;
    border:3px solid;
    -webkit-border-radius:5px;
    -moz-border-radius:5px;
    border-radius:5px;
}
.button.dark {
    border-color:#FFF;
    color:#FFF;
    background:#030303;
}
.button.dark > span {
    border-color:#000;
    -webkit-box-shadow: inset 0 3px 5px -1px rgba(255,255,255,0.3);
    -moz-box-shadow: inset 0 3px 5px -1px rgba(255,255,255,0.3);
    box-shadow: inset 0 3px 5px -1px rgba(255,255,255,0.3);
    background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/Pgo8c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjAlIiB5MT0iMCUiIHgyPSIwJSIgeTI9IjEwMCUiPgogICAgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2ZmZmZmZiIgc3RvcC1vcGFjaXR5PSIwLjMiLz4KICAgIDxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iI2ZmZmZmZiIgc3RvcC1vcGFjaXR5PSIwIi8+CiAgPC9saW5lYXJHcmFkaWVudD4KICA8cmVjdCB4PSIwIiB5PSIwIiB3aWR0aD0iMSIgaGVpZ2h0PSIxIiBmaWxsPSJ1cmwoI2dyYWQtdWNnZy1nZW5lcmF0ZWQpIiAvPgo8L3N2Zz4=);
    background: -moz-linear-gradient(top, rgba(255,255,255,0.3) 0%, rgba(255,255,255,0) 100%);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(255,255,255,0.3)), color-stop(100%,rgba(255,255,255,0)));
    background: -webkit-linear-gradient(top, rgba(255,255,255,0.3) 0%,rgba(255,255,255,0) 100%);
    background: -o-linear-gradient(top, rgba(255,255,255,0.3) 0%,rgba(255,255,255,0) 100%);
    background: -ms-linear-gradient(top, rgba(255,255,255,0.3) 0%,rgba(255,255,255,0) 100%);
    background: linear-gradient(to bottom, rgba(255,255,255,0.3) 0%,rgba(255,255,255,0) 100%);
}

有 2 个类(.button用于布局以及.dark用于颜色和渐变),因此您可以在页面中拥有不同类型的按钮。

于 2012-10-09T09:42:25.953 回答
0

检查此代码作为您查询的解决方案。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>

<style type="text/css">
    .btn-zen-inverse, .btn-zen-inverse:hover{
    color:#fff;
    background: 
    url("https://lh4.googleusercontent.com/-V_jjGSjquMg/UHPqq7_FfvI/AAAAAAAAA6s/fK5QEHGzC9I/s128/left.png") no-repeat right 0,
    url("https://lh4.googleusercontent.com/-V_jjGSjquMg/UHPqq7_FfvI/AAAAAAAAA6s/fK5QEHGzC9I/s128/left.png") no-repeat  left 0,
    url("https://lh3.googleusercontent.com/-JgxTtVru7R8/UHPqq1RgAII/AAAAAAAAA6o/gmfFayABGfQ/s128/center.png") repeat-x 42px 0;
  background-color: #ff09f9;
  background-size: contain; 
  line-height: 50px;
  margin: 12px 18px 3px 0;
  padding: 0;
  border: 2px solid white !important;
  text-align:center
}

</style>

</head>

<body>
<div class="btn-zen-inverse">Content</div>
</body>
</html>
于 2012-10-09T09:21:17.700 回答