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

标签 javascript raphael

作为一名桌面开发人员,我对 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/

相关文章:

javascript - Javascript 数组、对象和 RaphaelJS 的奇怪行为

javascript - 函数 getById Raphael js

javascript - Justgage.js 更改标题、值、标签字体大小

javascript - 更新到位置 : absolute 后检索到 $().position() 更改

javascript - 如何收集 AngularJS 中已选择的行的数据?

javascript - 在多边形中找到凸 Angular 和凹 Angular

javascript - 显式 jquery indexOf()

选择器 session 存储的 Javascript 问题

javascript - 如何使用 raphael js 添加额外的路径箭头到指针路径

javascript - 如何使用 Raphael 和 jQuery 检测 IE 上的点击或鼠标按下