0

我希望我的 svg 在其内部的按钮悬停时更改其填充。

<set attributeName="fill" to="#AEAEAE" begin="button.mouseover" end="button.mouseout"/>

我认为这会起作用,但它保留了 #FF702A 的原始填充

有人可以帮忙吗?

/////编辑//////

我对其进行了重构以使其更简单。除非我遗漏了一些主要概念,否则仅使用 css 应该是可能的?

这是html-

 <div id="button">show svg onhover
     <svg id="play" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" x="0px" y="0px" width="42px" height="62px" viewBox="0 0 24 32" style="enable-background:new 0 0 24 32;" xml:space="preserve" xmlns:xml="http://www.w3.org/XML/1998/namespace">
    <g id="Layer_1">
    </g>
    <g id="play">
      <polygon points="0,0 24,16 0,32  "/>      
    </g>
   </svg>
  </div>

这是相关的CSS

#button {

height: 75px;
width: 275px;
font-size: 25px;
text-align: center;
background: #FF702A;
border-radius: 10px;
padding-top: 40px;
margin-top: 70px;
margin-left: 150px;
opacity: 0.7;
letter-spacing: 1px;
font-variant: small-caps;
color: #EEEEEE; 

}

#button:hover {
opacity: 1.0;
font-size: .01em;

}

#play{
position: absolute;
margin-left: -90px;
margin-top: -10px;
visibility: hidden;

}

#play:hover {
visibility: visible;

}

在悬停时隐藏文本是一种技巧,但为什么 svg 的可见性在悬停时不起作用?很抱歉从原来的问题采取不同的方向,但希望这能澄清一点。希望用纯 css 完成..

4

1 回答 1

0

你也可以只用 CSS 做到这一点:

#button { fill: #FF702A; }
#button:hover { fill: #AEAEAE; }

如果您想知道为什么它不起作用,则必须将带有 id="button" 的元素(及其子元素,如果有的话)添加到问题中。

于 2012-07-16T10:50:11.210 回答