4

我在画布上有一堆 Raphael 元素对象,并且每个对象都有关联数据,如下所示:

element.data('dataVal',x);

在上面的例子中,我想知道 x 存储在哪里。我一直在查看 Raphael.js 的源代码,并专注于本节:

elproto.data = function (key, value) {
    var data = eldata[this.id] = eldata[this.id] || {};
    if (arguments.length == 1) {
        if (R.is(key, "object")) {
            for (var i in key) if (key[has](i)) {
                this.data(i, key[i]);
            }
            return this;
        }
        eve("raphael.data.get." + this.id, this, data[key], key);
        return data[key];
    }
    data[key] = value;
    eve("raphael.data.set." + this.id, this, value, key);
    return this;
};

所以,我的预感是“eldata”是 Raphael 纸对象的属性,“eldata”包含每个 Raphael 元素的对象,数据存储在这些对象中。

从本质上讲,我的问题是:一旦我创建了 Raphael 画布、添加元素并向这些元素添加数据,我将如何访问数据(不使用 Raphael 函数)?我尝试了一些简单的东西,比如寻找 R.eldata(其中 R 是 Raphael 画布),但这并没有什么成果。

感谢您的帮助!

4

1 回答 1

5

eldata是在闭包中定义的局部变量(v2.1.0 左侧的行号):

 233|  (function () {
....|
 254|      var loaded,
....|
 382|          eldata = {},
....|
2396|      elproto.data = function (key, value) {
....|
2413|      elproto.removeData = function (key) {
....|
3743|  })();

因为它是封闭的,它只能被同一个闭包中定义的函数访问。因此,您将不得不使用 RaphaeldataremoveData方法来访问它。

于 2012-05-03T21:23:38.110 回答