Creo que ahora he pillado bien el concepto de la explicación: la idea es asegurarse de que el bucle analiza exactamente el número de objetos que hay, no más ni menos, de ahí que haya que pasarle la referencia del número de objetos en lugar del número de objetos que se cree que hay. ¿Es así?
A decir verdad, el código que posteé en este hilo era para analizar unos radio buttons, en los que se preguntaba el sexo (solamente dos, hombre o mujer), por eso puse i==1 (....sexo[0] y ....sexo[1]). En cualquier caso, con la referencia del número de objetos funcina mejor que con el número de objetos directamente.
Ahora, aplicando tu explicación tal y como la he entendido, he pasado al bucle en el que se crea un número N de campos, de esta manera:
Código Javascript
:
Ver originalvar tracks=parseInt(prompt('¿Cuántas pistas tiene el disco?'));
if(!parseInt(tracks))
{
alert('En números, por favor');
newTrack();
}
else if(parseInt(tracks)&&tracks > 30)
{
alert('30 es un buen número para las canciones. Si el disco tiene más, pon las 30 primeras');
newTrack();
}
else //A partir de aquí es donde aparecen los errores
{
alert('este alert salta');
for(var w=1;w == tracks; w++)
{
alert('este alert NO salta, y tampoco se ejecuta la orden de abajo');
document.getElementById('tracklist').innerHTML='<input type="text" name="track'+w+"\"><br>\n";
}
alert('Este alert salta');
}
La lógica: dado un número N, facilitado por el usuario, crea campos input, comenzando con w=0, y hasta que w==N.
En este caso, lo mismo, el bucle no se ejecuta. Creo que esta vez si es apropiado dar un valor numérico como condición, ¿no? Así, está (o debería estar) creando campos hasta que el usuario decida que pare.