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

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


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值