我如何动画元素存储在一个数组?除了我徘徊在上面的那个
How do I animate elements stored in an array? except for the one I'm hovering over?
我有:
jQuery.each(shapes, function(i) {
this.hover(function(event) {
this.animate({
fill: "#fff"
}, 500);
}, function(event) {
this.animate({
fill: "#555"
}, 500);
});
});
我使用拉斐尔.js,但我认为这个问题是一般的jQuery语法。
因此,当我将鼠标悬停在一个元素(存储在形状中)上时,我希望该元素保持原样,但随后更改所有其他元素的不透明度。我不知道从哪里开始='
编辑:所以,我觉得,就语义而言,这应该工作:
jQuery.each(shapes, function(i) {
current_shape = this;
this.hover(function(event) {
jQuery.each(shapes, function(j){
if (shapes[users_with_direct_employees[j][0]] != current_shape){
shapes[users_with_direct_employees[j][0]].animate({
fill: "#fff"
}, 500);
}
});
}, function(event) {
jQuery.each(shapes, function(j){
if (shapes[users_with_direct_employees[j][0]] != current_shape){
shapes[users_with_direct_employees[j][0]].animate({
fill: "#555"
}, 500);
}
});
});
});
,但只有最后触摸的形状做动画。我将在这里创建一个js fiddel
小提琴:http://jsfiddle.net/G5mTx/1/
假设形状数组是一个DOM元素数组,我认为你可以使用这样的方法为每个形状设置一个悬停事件处理程序然后在传递给悬停事件处理程序的每个函数中,迭代形状数组如果不是你悬停的那个,你就做动画。
jQuery.each(shapes, function(i) {
this.hover(function(event) {
var self = this;
jQuery.each(shapes, function(index, value) {
if (value != self) {
$(value).animate({fill: "#fff"}, 500);
}
});
}, function(event) {
var self = this;
jQuery.each(shapes, function(index, value) {
if (value != self) {
$(value).animate({fill: "#555"}, 500);
}
});
});
});
或者使用局部函数更简洁:
jQuery.each(shapes, function(i) {
function animateIfNotMe(me, fillValue) {
jQuery.each(shapes, function(index, value) {
if (value != me) {
$(value).animate({fill: fillValue}, 500);
}
});
}
this.hover(function(event) {
animateIfNotMe(this, "#fff");
}, function(event) {
animateIfNotMe(this, "#555");
});
});
编辑:我看到你现在实际的代码添加到你的问题(因为我写的答案)和形状不是DOM对象数组(就好了如果你有透露,最初)显然这段代码完全行不通,但希望你可以从这段代码如何遍历所有其他形状和排除当前一个盘旋,你可以适应您的特定形状的数据结构。
您可以使用。not()方法:
jQuery.each(shapes, function(i) {
$(this).hover(function(event) {
shapes.not($(this)).animate({
相关文章:
- Javascript(Angular)从一个对象数组到第二个数组查找值
- 根据id将json数组组合为一个json数组
- JavaScript数组包含一个值
- 对一个对象使用reduce可以返回一个没有't在数组中包含目标字母
- jQuery$.inArray()总是返回-1和一个对象数组
- 在数组中的一个元素上设置多个值
- javascript处理一个对象数组以获得一个新的对象数组
- 作为一个二维数组,从ajax接收
- 你能用来自数组的属性名称生成一个对象吗
- 多维关联数组的最后一个索引
- 如何创建一个方法来验证数组的范围
- 循环以检查数组中的最后一个图像
- 在Javascript中将一个值和字符串数组转换为if语句
- 算法:从数组(javascript/angular)中按当前日期获取上一个和下一个事件
- 如何将一个对象添加到每个对象数组中
- 如何创建一个谷歌地图地理坐标数组
- 如何从另一个带下划线的数组中筛选带元素的数组
- 如何在PHP数组中加载下一个youtube
- 查找对象数组是否包含其中一个标记的最快方法
- 如何使用Javascript和Ajax传递一个HTML选择标签到PHP $_POST与一个(数组)var当名称属性是一个