这应该相当简单,但我明白为什么它不起作用。我希望有一个聪明的方法来做到以下几点:
我有一个字符串'movieclip1.movieclip2'
我有一个容器动画片段 - 容器。
现在通常会评估字符串:
this.container['movieclip']['movieclip2']
因为clip2是movieclip的孩子。
但我想用点语法解析或评估字符串,将字符串作为内部路径读取。
this.container[evaluatedpath]; // which is - this.container.movieclip.movieclip2
是否有能够将该字符串评估为内部路径的函数或技术?
感谢。
答案 0 :(得分:2)
据我所知,无法使用类似路径的参数浏览DisplayList,无论是[]
还是getChildByName
。
但是,您可以编写自己的函数来实现类似的效果(测试和工作):
/**
* Demonstration
*/
public function Main() {
// returns 'movieclip2':
trace((container['movieclip']['movieclip2']).name);
// returns 'movieclip':
trace(path(container, "movieclip").name);
// returns 'movieclip2':
trace(path(container, "movieclip.movieclip2").name);
// returns 'movieclip2':
trace(path(container, "movieclip#movieclip2", "#").name);
// returns null:
trace(path(container, "movieclip.movieclipNotExisting"));
}
/**
* Returns a DisplayObject from a path, relative to a root container.
* Recursive function.
*
* @param root element, the path is relative to
* @param relativePath path, relative to the root element
* @param separator delimiter of the path
* @return last object in relativePath
*/
private function path(root:DisplayObjectContainer,
relativePath:String, separator:String = ".") : DisplayObject {
var parts:Array = relativePath.split(separator);
var child:DisplayObject = root.getChildByName(parts[0]);
if (parts.length > 1 && child is DisplayObjectContainer) {
parts.shift();
var nextPath:String = parts.join(separator);
var nextRoot:DisplayObjectContainer = child as DisplayObjectContainer;
return path(nextRoot, nextPath, separator);
}
return child;
}