如何突破Class中的范围限制[Flash8 Guys]

王朝other·作者佚名  2006-01-09
宽屏版  字体: |||超大  

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", "突破范围限制");

};

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有