2013-04-09 81 views
1

我试图在右下角有一个透明遮罩实现了矩形按钮,按本小提琴CSS按钮:与倾斜右下角

http://jsfiddle.net/c6gUX/

body { 
background: #fff; 
padding: 5em; 
} 
.button { 
    color: #FFFFFF; 
    font-family: 'RalewayRegular', Arial,sans-serif; 
    font-size: 1em; 
    padding: 0.5em 1.2em 0.5em 0.8em; 
    position: relative; 
    text-decoration: none; 
} 
.button:hover { 
    background: linear-gradient(to bottom, #FFA13E 0px, #E56204 100%) repeat scroll 0 0 transparent; 
    color: #FFFFFF; 
} 
.button:after { 
    background: url(http://i.imgur.com/8Vvw1Sw.png) no-repeat scroll 0 0 transparent; 
    bottom: -12px; 
    content: " "; 
    height: 38px; 
    position: absolute; 
    right: -12px; 
    width: 36px; 
    z-index: 99; 
} 
.orange-grad { 
    background: #ffa13e; /* Old browsers */ 
    /* IE9 SVG, needs conditional override of 'filter' to 'none' */ 
    background: url(); 
    background: -moz-linear-gradient(top, #ffa13e 0%, #ff7805 100%, #ff7805 100%); /* FF3.6+ */ 
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ffa13e), color-stop(100%,#ff7805), color-stop(100%,#ff7805)); /* Chrome,Safari4+ */ 
    background: -webkit-linear-gradient(top, #ffa13e 0%,#ff7805 100%,#ff7805 100%); /* Chrome10+,Safari5.1+ */ 
    background: -o-linear-gradient(top, #ffa13e 0%,#ff7805 100%,#ff7805 100%); /* Opera 11.10+ */ 
    background: -ms-linear-gradient(top, #ffa13e 0%,#ff7805 100%,#ff7805 100%); /* IE10+ */ 
    background: linear-gradient(to bottom, #ffa13e 0%,#ff7805 100%,#ff7805 100%); /* W3C */ 
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffa13e', endColorstr='#ff7805',GradientType=0); /* IE6-8 */ 
} 

正如你所看到的,我用一种相当古怪的方式实现了它。我没有测试过这个跨浏览器,并怀疑IE搞砸了没有垫片:之后等。

我该如何实现这种跨浏览器的现代?如何在叠加到图像上时使其工作,以便它有效透明? (见下图)

从PSD:

enter image description here

我在图像上小提琴:

enter image description here

按道理我知道IE6/7需要一个像我”米有点不错。

字长。有时按钮没有“阅读更多”,所以需要100%宽度的解决方案。

编辑

我想用雪碧。 (http://i.imgur.com/z0UYpTX.png

+0

如果您要为旧版浏览器使用图片,为何不在现代浏览器中使用相同的解决方案? – Johan 2013-04-09 08:45:41

+0

我同意。如果您对旧版浏览器使用图片,则对标准图片使用相同的图片。否则,我不确定IE6-7会喜欢CSS3图像叠加。 – casraf 2013-04-09 08:50:00

+0

单词并不总是相同的长度。我很高兴我不是唯一认为这很困难的人。 – SMacFadyen 2013-04-09 08:52:40

回答

5

这很棘手 - 尤其是当您将梯度与斜角相结合时。我能得到的最接近的数字是this fiddle,它利用CSS渐变来达到你以后的效果,基于Lea Verou的awesome article

相关的CSS是:

.button {  
    background: #ffa13e; /* fallback */ 
    background: -webkit-linear-gradient(135deg, transparent 10px, #ff7805 10px, #ffa13e 100%); 
    background: -moz-linear-gradient(135deg, transparent 10px, #ff7805 10px, #ffa13e 100%); 
    background: -o-linear-gradient(135deg, transparent 10px, #ff7805 10px, #ffa13e 100%); 
    background: linear-gradient(315deg, transparent 10px, #ff7805 10px, #ffa13e 100%); 
} 

这是得到的背景图像,显示通过(据我所知)的唯一途径。缺点是梯度不是从上到下的线性梯度,而是一个角度。我不认为它可以结合多个渐变,以准确地匹配你的视觉。但它是非常接近:

Gradient beveled effect

我认为,这是渐进增强的最佳人选 - 旧的IE会得到一个坚实的背景颜色但这是完全可以接受的(即我不会亲自过问尝试对于图像回退)。

注:有过的工作草案和用于梯度语法,其中的一个是梯度的角度的候选推荐之间许多变化:

Gradient degrees syntax change

IE Blog。因此,前缀版本需要不同的deg值。

+0

好吧,我只是学到了很多:)谢谢你,很好的答案。 +10小猫点为身体bg。 – SMacFadyen 2013-04-09 10:24:18

+0

没问题 - 是一个有趣的尝试和弄清楚。如果我可以的话,我会一直用小猫来说明一个观点:) – CherryFlavourPez 2013-04-09 10:33:14

0

利用它.....我认为这将有助于你..用它与UR形象..这将解决跨浏览器的问题...

http://jsfiddle.net/Praveen16oct90/2bZAW/1095/

div { 
    width:200px; 
    height:80px; 
    background: red; 
    top:150px;left:100px; 
    position: relative; 
    } 

div:before { 
      content: ''; 
      position: absolute; 
      top: 40px; right: 0; 
      border-right: 40px solid white; 
      border-top: 40px solid red; 
      width: 20; 
     } 
+0

嗨,好的小提琴。但请看我需要灵活的宽度:)也许与我的精灵? http://i.imgur.com/z0UYpTX.png – SMacFadyen 2013-04-09 09:07:34

+0

不能得到你..你是否希望我这样做与你的形象是这样的...如果s发送该图像...你粘贴上面 – PraJen 2013-04-09 09:13:37

+0

像这样:http://jsfiddle.net/u2ENb/ - 如果我使用精灵,它不是水平重复。 (小1px的东西)。 – SMacFadyen 2013-04-09 09:29:51