在编写JAVASCRIPT代码过程中,有时候会经常对函数进行自调用,也就是函数递归,
JAVASCRIPT允许函数递归,但是有其自己的递归原则,
¿Ver copia simple en el portapapeles?
<mce:tipo de script="texto/javascript"><!--
tipo var=6;
función actual (a)
{
var i=0;
si(a==indefinido)
{
actual(1);
devolver;
}
if(document.getElementById("cursores"+a)==null&&type>a)
{
actual(a*2);
devolver;
}
valor var=1;
mientras(tipo>=valor)
{
obj=document.getElementById("elemento"+valor);
if(obj!=null)obj.className='oculto';
obj=document.getElementById("cursores"+valor);
if(obj!=null)obj.className='detrás';
yo ++;
valor=Math.pow(2,i);
}
if((obj=document.getElementById("item"+a))!=null)obj.className='show';
if((obj=document.getElementById("cursores"+a))!=null)obj.className='actual';
}
// --></mce:script>
<mce:tipo de script="texto/javascript"><!--
tipo var=6;
función actual (a)
{
var i=0;
si(a==indefinido)
{
actual(1);
devolver;
}
if(document.getElementById("cursores"+a)==null&&type>a)
{
actual(a*2);
devolver;
}
valor var=1;
mientras(tipo>=valor)
{
obj=document.getElementById("elemento"+valor);
if(obj!=null)obj.className='oculto';
obj=document.getElementById("cursores"+valor);
if(obj!=null)obj.className='detrás';
yo ++;
valor=Math.pow(2,i);
}
if((obj=document.getElementById("item"+a))!=null)obj.className='show';
if((obj=document.getElementById("cursores"+a))!=null)obj.className='actual';
}
// --></mce:script>
请看current函数,函数体内嵌套了递归,这里是单项运行,即递归一次后便用return结束运行,
当然你也可以递归完后继续运行,JAVASCRIPT不排斥这个!
使用递归可以让你的代码看起来更完整,但是千万小心不能让他陷入死循环