突破Class中的范围限制的方法

突破Class中的范围限制的方法

Poster: Super-Tomato

我想学习过Class的朋友都会遇到一些范围方面的限制,例如在Class当中使用onKeyDown等事件无法调用别的函数,几乎很多网页也都只是单纯的解说方法而没有提到这点。在这里就教大家一个小技巧突破这个范围

 

class testing {

function testing() {

trace(this); //在这里的this是指testing本身

var myKey:Object = new Object();

myKey.onKeyDown = function() {

trace(this); //这里的this是指myKey

echo ("突破范围限制"); //当然你也可以使用_root.test.echo(), 但是这样的代码就无法灵活的应用在其他地方了

}

Key.addListener(myKey);

}

private function echo(str:String) {

trace(str);

}

}

---------------------- FLA ---------------------------

var test:testing = new testing();

 

 

解决方法很简单, 如下:

class testing {

function testing() {

var root:Object = this;

var myKey:Object = new Object();

myKey.onKeyDown = function() {

root.echo ("突破范围限制");

}

Key.addListener(myKey);

}

private function echo(str:String) {

trace(str);

}

}

测试之后是否出来了呢 ^_^

holybozo===========================================================================

茄茄是利用了flash的scope来解决的,蛮好的,偶一直这么用,或者给obj定义一个parent

 

 

var myKey:Object = {parent:this};
myKey.onKeyDown = function ()
{
this.parent.echo ("突破范围限制");
};
Key.addListener (myKey);

不过道理是一样,用法还是茄茄的好^^"

最简单的方法 var myKey:Object = new Object(this);

LeeFJ===================================================================

但是我这里有一个更好的解决方法,大家可以参考一下,关于Delegate类,大家可以看看我在CSDN的BLOG:
http://blog.csdn.net/9116/ RSS:http://blog.csdn.net/9116/Rss.aspx ,非常支持番茄大王的写法,我在写FDO的时候就是用他那种方法的

 

import mx.utils.Delegate;
class testing
{
var NAME="番茄大王"
function testing ()
{
//var root:Object = this;
var myKey:Object = new Object ();
myKey.onKeyDown=Delegate.create (this, onKeyDown);
Key.addListener (myKey);
}
private function onKeyDown ()
{
trace (Key.getCode());
trace (NAME);
}
}


holybozo ============== ================================================

方法肯定还有很多

 

好的方法,我觉得差不多了??这里还有一个,是用监听的,不知道怎么样,呵呵

var myKey:Object = new Object ();

AsBroadcaster.initialize (myKey);
myKey.addListener (this);
myKey.onKeyDown = function ()
{
this.broadcastMessage ("echo", "突破范围限制");
};