2015-09-23 36 views

回答

4

转换只能应用于演示属性,以及一些其他属性,如X,Y,CX,CY ... 支持的属性列表可以在这里找到http://dev.w3.org/SVG/proposals/css-animation/animation-proposal.html 不幸的是d ISN其中之一...

因为这仍然不支持可靠跨浏览器,您可以使用SMIL动画来实现相同的结果。

var type = true; 
 

 
setInterval(function() { 
 
    $("#path").attr('from', type ? "M 0 0 L 50 100" : "M 0 0 L 100 50"); 
 
    $("#path").attr('to', type ? "M 0 0 L 100 50" : "M 0 0 L 50 100"); 
 
    $("#path")[0].beginElement() 
 
    $("#circle").attr('from', type ? "40" : "10"); 
 
    $("#circle").attr('to', type ? "10" : "40"); 
 
    $("#circle")[0].beginElement() 
 
    type = !type; 
 
}, 1000);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<svg> 
 
    <path stroke="#000000" stroke-width="5" d="M 0 0 L 100 50" > 
 
     <animate id="path" attributeName="d" from="M 0 0 L 100 50" to="M 0 0 L 50 100" dur="1s" fill="freeze"/> 
 
    </path> 
 
    <circle fill="#0000FF" cx="10" cy="50" r="10" > 
 
     <animate id="circle" attributeName="cx" from="10" to="40" dur="1s" fill="freeze"/> 
 
    </circle> 
 
</svg>

对我的方式重构我的所有代码使用`SVG
+0

:line',而不是'SVG:path' ......妈...... – codingtwinky

+0

https://jsfiddle.net/ rnhu7673/4 /更改为行,尽管x2和y2在文档中,但它不生成动画。 – codingtwinky

+1

你是对的,链接的网站是一个提案,并不是所有的属性都支持到处。例如,你的小提琴在firefox中根本不起作用。最安全的方式是在过渡不起作用的情况下使用SMIL ... –