丸みを帯びたエッジを持つ 3D ボタンを実装したい Web サイトを開発しています。そのためには、CSS ファイルを作成する必要があります。3D ボタンについてよく検索しますが、まだ何も機能していません。
4 に答える
次の css スタイルの組み合わせを使用したいと考えています: border
、border-radius
、background
、text-shadow
および finally box-shadow
。
これらで 3D 効果を実現するには、スタイルでグラデーション値を使用する必要があります。background
クロス ブラウザーのグラデーション 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
これは、最新のすべてのブラウザで問題なく動作し、IE8-6 (これは をサポートしていませんborder-radius
) でも問題ありません。この方法も画像を使用しません。
この質問、Google の Imageless Buttonsもチェックしてください。これは、Google がさまざまなボタンをどのように作成したかを説明していCSS
ます。
IE9 バグ
border-radius
が設定されている場合、IE9 にはレンダリングに関するバグがありますfilter
。修正は、次の IE9CSS
を CSS グラデーションを使用するすべての要素にのみ追加することです。
<!--[if gte IE 9]>
<style type="text/css">
.gradient {
filter: none;
}
</style>
<![endif]-->
http://css3button.net/をご覧ください。
http://www.cssbuttongenerator.com/を試してみてください
ボタンのスタイル設定が完了したら、ボタンをクリックすると、対応する CSS が下部のボックスに表示されます。
<style>
button {
-webkit-border-radius: 3px;
-moz-border-radius: 3px;
border-radius: 3px;
}
</style>
<button>Test</button>