for循环与退出循环 |
| 作者:佚名 来源:闪吧 作者: 鬼市 更新:2007-1-13 20:46:05 错误报告 我要投稿 |
点击浏览该文件
点击浏览该文件 使用for 是优化AS的重要手段。如果我们要对20个MC实现响应鼠标点击事件,如果不用for而直接写那么需要几十乃至几百行,而用for只需要用几行就可以了。看我们实现这样的效果: 对舞台上的20个MC点击,在MC中的动态文本中显示出该MC的实例名. 步骤:1、 制作一个MC,MC中包含一个动态文本,实例名为txt。2、按住ctrl,拖动复制出20个MC出来。3、为每个MC输入实例名mc0、mc1、mc2...mc19,然后选中桢,打开动作面板,输入以下语句。
mc0.onPress = function() { this.txt.text = this._name; }; mc1.onPress = function() { this.txt.text = this._name; }; ..... mc19.onPress = function() { this.txt.text = this._name; }; 以上语句共60行,实现了点击MC,在MC中的动态文本txt中显示该MC的实例名,如果有100个MC,那么照这样就需要300行,挺吓人的。现在用for几行搞定。
for(var i=0;i<20;i++){ this["mc"+i].onPress=function(){ this.txt.text=this._name } } 我们分析一下这个for是怎样解决问题的:for(var i=0;i<20;i++)共会读取20次,第一次i=0;检查i是否小于20,检查到符合条件,执行i++,于是i=1了,然后执行{}中的语句;第二次i=1;检查i是否小于20,检查到符合条件,执行i++,于是i=2了,然后执行{}中的语句;第三次i=2;检查i是否小于20,检查到符合条件,执行i++,于是i=3了,然后执行{}中的语句;......第二十一次i=20;检查i是否小于20,检查到不符合条件,执行i++,于是i=21了,此时循环结束,退出循环。 第一次执行的程序即是
this["mc"+0].onPress=function(){//同this.mc0.onPress=function() this.txt.text=this._name } 第二次执行的程序即是
this["mc"+1].onPress=function(){//同this.mc1.onPress=function() this.txt.text=this._name } 第三次执行的程序即是
this["mc"+2].onPress=function(){//同this.mc2.onPress=function() this.txt.text=this._name } ...... 由此,我们可以看到,for对于简化语句有非常重要的作用,适用for适用于MC的实例名是连续的情况,即mc0、mc1、mc2...,如果MC的实例名不是连续的,那么可以利用数组来解决这个问题,首先将MC的实例名作为数组中的元素,然后进行调用,如下:
var myarr=["mc0","mc1",""mc2","mc3"....] for(var i=0;i<20;i++){ this[myarr[i]].onPress=function(){ this.txt.text=this._name } } 以上介绍了for的使用,现在介绍一下如何中途退出for循环,如果我们只对10个MC进行读取,那么
for (var i = 0; i<20; i++) { if (i>=10) { break; } this["mc"+i].onPress = function() { this.txt.text = this._name; }; } 如果我们只不读取第10个,那么
for (var i = 0; i<20; i++) { if (i == 10) { continue; } this["mc"+i].onPress = function() { this.txt.text = this._name; }; }
|
|
| 文章录入:skyuu 责任编辑:skyuu |
|
| 【字体:小 大】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口】 |