3

背景:我正在使用 snap.svg 为内联 svg 中的路径设置动画,并且我试图在一个函数中为多个路径设置动画。

问题:使用下面的代码,我只能在一个抓取功能中选择一个路径。在下面的代码中,我使用了多个选择器,但动画只影响 rect#rect-one。如何在 Snap.svg 中选择多个路径?

谢谢您的帮助!

HTML/内联 SVG

<a id="one">link</a>

<svg>
<rect  id="rect-one" fill="#231F20" width="39" height="14"/>
<rect id="rect-two" x="54" fill="#231F20" width="39" height="14"/>
<rect id="rect-three" x="104" fill="#231F20" width="39" height="14"/>
</svg>

快照

window.onload = function () {
    var grabLink = Snap.select('body a#one'),
        grabPathRectangles = Snap.select('#rect-one, #rect-two, #rect-three');

    function colorPathRectangles(){
        grabPathRectangles.animate({fill: 'red'}, 100, mina.ease);
    } 
    function resumePathRectangles(){
        grabPathRectangles.animate({fill: 'green'}, 100, mina.ease);
    }   
    grabLink.hover(colorPathRectangles, resumePathRectangles);  
};
4

2 回答 2

5

我认为问题在于您不能将动画应用于集合(编辑:现在可能),因此您必须将其应用于每个元素。为此,您可以使用 forEach 命令,所以...

 grabPathRectangles.forEach( function(elem,i) {
        elem.animate({fill: 'red'}, 1000, mina.ease);
  });

Jsfiddle在这里... http://jsfiddle.net/DZ4wZ/3/

或者我怀疑你可以把它们放到一个组中,如果这样更有意义的话,可以把这个组动画化。这是一个示例http://jsfiddle.net/DZ4wZ/5/但是,我必须删除原始填充。

编辑:看起来你现在可以将动画应用到一组,我认为这个功能过去不工作,或者是错误的,所以历史上没有使用过。因此,如果使用 Snap,您可能需要确保拥有最新版本的 Snap。

于 2013-11-25T13:27:42.863 回答
5

不幸的是,@Ian 的回答是不正确的,尽管他的小提琴默默地解决了实际问题。

问题是您使用Snap.select而不是Snap.selectAll查询多个元素。Select 只会带回满足选择器的第一个实例,而 selectAll 将获取所有实例并作为 Element 对象的集合或数组返回。这就是为什么只有一个元素响应动画。

此外,您绝对可以animate同时调用一组元素,因此无需使用额外的 for 循环使事情复杂化。

从上的文档Set.animate()

同步地为集合中的每个元素设置动画。

这是一个使用 Stack Snippets 的工作演示。

它首先记录 select 和 SelectAll 的不同输出

console.log("select:    ", Snap.select(   '#rect-1, #rect-2, #rect-3'));
console.log("selectAll: ", Snap.selectAll('#rect-1, #rect-2, #rect-3'));

var grabLink = Snap.select('#one'),
    grabPathRectangles = Snap.selectAll('#rect-1, #rect-2, #rect-3');

function colorPathRectangles(){
  grabPathRectangles.animate({fill: 'red'}, 1000, mina.ease);
} 
function resumePathRectangles(){
  grabPathRectangles.animate({fill: 'green'}, 1000, mina.ease);
}   

grabLink.hover(colorPathRectangles, resumePathRectangles);  
a#one {
  display: block;
  border: 1px solid blue;
  margin-bottom: 15px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/snap.svg/0.3.0/snap.svg-min.js"></script>

<a id="one">Hover Me</a>

<svg>
  <rect id="rect-1" fill="#231F20" width="39" height="14"/>
  <rect id="rect-2" fill="#231F20" width="39" height="14" x="54" />
  <rect id="rect-3" fill="#231F20" width="39" height="14" x="104" />
</svg>

于 2015-01-06T18:08:04.507 回答