在编写JAVASCRIPT代码过程中,有时候会经常对函数进行自调用,也就是函数递归,
JAVASCRIPT允许函数递归,但是有其自己的递归原则,
visualizar cópia simples para impressão da área de transferência?
<mce:script type="text/javascript"><!--
var tipo=6;
corrente de função(a)
{
var i=0;
if(a==indefinido)
{
atual(1);
retornar;
}
if(document.getElementById("cursores"+a)==null&&type>a)
{
atual(a*2);
retornar;
}
var valor=1;
while(tipo>=valor)
{
obj=document.getElementById("item"+valor);
if(obj!=null)obj.className='oculto';
obj=document.getElementById("cursores"+valor);
if(obj!=null)obj.className='atrás';
eu++;
valor=Math.pow(2,i);
}
if((obj=document.getElementById("item"+a))!=null)obj.className='show';
if((obj=document.getElementById("cursores"+a))!=null)obj.className='atual';
}
// --></mce:script>
<mce:script type="text/javascript"><!--
var tipo=6;
corrente de função(a)
{
var i=0;
if(a==indefinido)
{
atual(1);
retornar;
}
if(document.getElementById("cursores"+a)==null&&type>a)
{
atual(a*2);
retornar;
}
var valor=1;
while(tipo>=valor)
{
obj=document.getElementById("item"+valor);
if(obj!=null)obj.className='oculto';
obj=document.getElementById("cursores"+valor);
if(obj!=null)obj.className='atrás';
eu++;
valor=Math.pow(2,i);
}
if((obj=document.getElementById("item"+a))!=null)obj.className='show';
if((obj=document.getElementById("cursores"+a))!=null)obj.className='atual';
}
// --></mce:script>
请看current函数,函数体内嵌套了递归,这里是单项运行,即递归一次后便用return结束运行,
当然你也可以递归完后继续运行,JAVASCRIPT不排斥这个!
使用递归可以让你的代码看起来更完整, 但是千万小心不能让他陷入死循环