gpt4 book ai didi

javascript - 从外部方法调用时 RaphaelJS animate 不起作用

转载 作者:行者123 更新时间:2023-11-28 01:02:11 25 4
gpt4 key购买 nike

作为一名桌面开发人员,我对 Javascript 非常陌生,因此我经常遇到一些让我对这门语言感到困惑的事情。我正在处理 RaphaelJS 形状上的单击事件,最初我在私有(private)方法中设置对象的状态和动画:

innershape.node.onclick = function () {
if (scope.state === 0) {
_setState(1);
} else {
_setState(0);
}
};

function _setState(state) {
scope.state = state;
if (scope.state === 0) {
innershape.animate({ fill: "#00FF19" }, 500);
} else {
innershape.animate({ fill: "#C05219" }, 500);
}
}

这按预期运行。然后,我决定添加一个外部函数,该函数将循环遍历所有对象并取消选择(因此反向动画)所有其他形状。结果可以在这个jsfiddle中看到:http://jsfiddle.net/txj4zasn/4/

函数被正确调用,animate()函数显然被执行,但可见动画从未出现,颜色也从未改变。我怀疑这是 Javascript 的一些非常基本的东西,我只是不明白。有人可以向我解释为什么会发生这种情况吗?

最佳答案

目前还不清楚您想要实现什么(除了让动画正常工作之外),因此我认为我最初的解决方案并不好,但我会对此进行扩展。

这个问题看起来有点像您试图组合两个不同的元素:功能范围和对象变量。

一个快速的解决方案是包含...

this.id = 1; 
var id = this.id; // so id now a closure to the later function

as updateSelected(id);这里的 id 在另一个函数中,所以我们不能使用“this.id”。但稍后您要检查 z[i].id,因此您还需要定义它。

jsfiddle

这一切感觉有点笨拙,容易出错,而且很难阅读。所以第一个问题是你需要对象吗?您可以将信息存储在 Raph 元素的“数据”部分中,该部分已经是一个对象。

这是我如何编写它的一个示例,我知道这可能不合适,因为它可能是一个更大的项目的一部分,该项目需要对象中的其他元素,但它可能会提供一些想法。

function updateSelected( el ) {
if( el.data('innerstate') == 1 ) {
el.animate({ fill: "#00FF19" }, 500);
el.data('innerstate',0)
} else {
el.animate({ fill: "#C05219" }, 500);
el.data('innerstate',1);
}

}

function addElement() {
var innershape = paper.rect(100,100,100, 100);
innershape.attr({fill: "#00FF19" });
innershape.data('innerstate', 0);
innershape.click( function () {
updateSelected( innershape )
} );

};

addElement();

我几乎可以立即阅读这段代码,并知道它如何工作以及是否有效。

jsfiddle

jsfiddle显示它与多个元素的组合,或 jsfiddle这样更紧凑一点

关于javascript - 从外部方法调用时 RaphaelJS animate 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25489612/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com