是否有可能将纸张中存在的元素或集合添加到另一张纸张中,而不是从头开始两次创建每个元素?
背景:我想象一个大型节点图,并希望在另一篇论文中创建一个“概述图”。
答案 0 :(得分:3)
以下一组代码为Raphael Set和Raphael Elements添加了一个nw函数。用法是简单地在任何集合或元素上调用.cloneToPaper(targetPaper)
。
(function (R) {
var cloneSet; // to cache set cloning function for optimisation
/**
* Clones Raphael element from one paper to another
*
* @param {Paper} targetPaper is the paper to which this element
* has to be cloned
*
* @return RaphaelElement
*/
R.el.cloneToPaper = function (targetPaper) {
return (!this.removed &&
targetPaper[this.type]().attr(this.attr()));
};
/**
* Clones Raphael Set from one paper to another
*
* @param {Paper} targetPaper is the paper to which this element
* has to be cloned
*
* @return RaphaelSet
*/
R.st.cloneToPaper = function (targetPaper) {
targetPaper.setStart();
this.forEach(cloneSet || (cloneSet = function (el) {
el.cloneToPaper(targetPaper);
}));
return targetPaper.setFinish();
};
}(Raphael));
对于示例实现,您可以查看这个小提琴:http://jsfiddle.net/shamasis/39yTS/
请注意,如果源元素上有事件,则不会将它们克隆到目标文件中。
答案 1 :(得分:1)
Raphael不允许将元素从一张纸直接移动到另一张纸。 因此,最好在目标文件中创建具有相同属性的新元素。 我创建了以下示例方法。您可以在页面中添加代码,并使用cloneToPaper函数将元素或集合克隆到另一张纸上。
function extractJSON(element) {
var attr = element.attr(),
newNodeJSON = {type: element.type},
key;
for (key in attr) {
newNodeJSON[key] = attr[key];
}
return newNodeJSON;
}
/*
* @param {Object} element: raphael element or set
* @param {Object} paper: Target paper where to clone
* @return {object}: newly created set or element
*/
function cloneToPaper(element, paper) {
var isSet = element.type === 'set',
elementJSONArr = [],
i, ln, newSet;
if (isSet) {
ln = element.items.length;
for (i = 0; i < ln; i += 1) {
elementJSONArr.push(extractJSON(element.items[i]));
}
}
else {
elementJSONArr.push(extractJSON(element));
}
newSet = paper.add(elementJSONArr);
return isSet ? newSet : newSet[0];
}