JavaScript « Как с помощью цикла for создать несколько переменных?
Как с помощью цикла можно создать несколько переменных? например:
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .javascript.geshi_code {font-family:monospace;} .javascript.geshi_code .imp {font-weight: bold; color: red;} .javascript.geshi_code .kw1 {color: #000066; font-weight: bold;} .javascript.geshi_code .kw2 {color: #003366; font-weight: bold;} .javascript.geshi_code .kw3 {color: #000066;} .javascript.geshi_code .co1 {color: #006600; font-style: italic;} .javascript.geshi_code .co2 {color: #009966; font-style: italic;} .javascript.geshi_code .coMULTI {color: #006600; font-style: italic;} .javascript.geshi_code .es0 {color: #000099; font-weight: bold;} .javascript.geshi_code .br0 {color: #009900;} .javascript.geshi_code .sy0 {color: #339933;} .javascript.geshi_code .st0 {color: #3366CC;} .javascript.geshi_code .nu0 {color: #CC0000;} .javascript.geshi_code .me1 {color: #660066;} .javascript.geshi_code span.xtra { display:block; }
нужно что бы получилось что то типо:
point_0 =...
point_1 =...
point_2 =...
point_3 =...
Как это можно сделать? Мой вариант не работает(
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .javascript.geshi_code {font-family:monospace;} .javascript.geshi_code .imp {font-weight: bold; color: red;} .javascript.geshi_code .kw1 {color: #000066; font-weight: bold;} .javascript.geshi_code .kw2 {color: #003366; font-weight: bold;} .javascript.geshi_code .kw3 {color: #000066;} .javascript.geshi_code .co1 {color: #006600; font-style: italic;} .javascript.geshi_code .co2 {color: #009966; font-style: italic;} .javascript.geshi_code .coMULTI {color: #006600; font-style: italic;} .javascript.geshi_code .es0 {color: #000099; font-weight: bold;} .javascript.geshi_code .br0 {color: #009900;} .javascript.geshi_code .sy0 {color: #339933;} .javascript.geshi_code .st0 {color: #3366CC;} .javascript.geshi_code .nu0 {color: #CC0000;} .javascript.geshi_code .me1 {color: #660066;} .javascript.geshi_code span.xtra { display:block; }
нужно что бы получилось что то типо:
point_0 =...
point_1 =...
point_2 =...
point_3 =...
Как это можно сделать? Мой вариант не работает(
1 ответов
Если вам нужно создать кучу переменных в цикле, то это можно сделать с помощью eval
for(i=0;i<10;i++){
eval("var point_"+i+"="+10*i)
}
Тогда в глобальной области видимости создадутся переменные
point_1 = 10;
point_2 = 20;
....
point_9 = 90;
Но, это неправильный подход! И так делать не нужно.Это засорение глобальной области видимости, ненужное использование eval.
Используйте массивы
var point;
for(i=0;i<10;i++){
point[i] = new Point(10, 10);
}
for(i=0;i<10;i++){
var point[i] = 10*i;
}
Где-то так, только возможно нужно вначале проинициализировать point как массив.
point[0] =...
point[1] =...
point[2] =...
point[3] =...
for(i=0;i<10;i++){
window['point_' + i] = 10*i;
}
Однако, так делать строго не рекомендую. Есть тысяча и 1 способ решать подобные задачи адекватнее, и главный из них - массивы и собственные объекты.
window['point_' + i] = 10*i;
}
Однако, так делать строго не рекомендую. Есть тысяча и 1 способ решать подобные задачи адекватнее, и главный из них - массивы и собственные объекты.