Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
32 / 31 / 21
Регистрация: 13.07.2014
Сообщений: 374

Оптимизация setInterval()

04.10.2014, 15:14. Показов 1483. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В данном коде слишком много setInterval(). Вопрос и проблема в том как оптимизировать так чтобы было n-ое количество setInterval -ов

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
var robotNameIndex = 0;
var kollDiv = new Array();
var indexKoll = 0;
var ser = -1;
var interr;
var kl = setInterval( "klone()","200" );
 
        function klone () {
            robotNameIndex++;
            
            kollDiv[indexKoll] = document.body.appendChild(document.createElement( "div" ));
            
            var nameAttr1 = document.createAttribute( 'id' ); // создаем атрибут
            nameAttr1.value = "r" + robotNameIndex;  // устанавливаем значение
            kollDiv[indexKoll].attributes.setNamedItem( nameAttr1 ); // привязываем атрибут
            
            var nameAttr1 = document.createAttribute( 'style' ); // создаем атрибут
            nameAttr1.value = "top:400px;left:400px;";  // устанавливаем значение
            kollDiv[indexKoll].attributes.setNamedItem( nameAttr1 ); // привязываем атрибут
            
            indexKoll++;
            ser++
            starter();
            //-----------------------------------------------..............
                    if( kollDiv.length > 24 ) {
                    clearInterval( kl )
                    }
        }
var inFor = -1;
var arrayFor = 0;
        function starter() {    
            inFor++
            if( kollDiv.length > inFor ) {  
            vdoh(kollDiv[inFor])
            
            }
        }
        //----------------------------------test
        setInterval( "vdoh( kollDiv[0])" , 15 );
        setInterval( "vdoh( kollDiv[1])" , 15 );
        setInterval( "vdoh( kollDiv[2])" , 15 );
        setInterval( "vdoh( kollDiv[3])" , 15 );
        setInterval( "vdoh( kollDiv[4])" , 15 );
        setInterval( "vdoh( kollDiv[5])" , 15 );
        setInterval( "vdoh( kollDiv[6])" , 15 );
        setInterval( "vdoh( kollDiv[7])" , 15 );
        setInterval( "vdoh( kollDiv[8])" , 15 );
        setInterval( "vdoh( kollDiv[9])" , 15 );
        setInterval( "vdoh( kollDiv[10])" , 15 );
        setInterval( "vdoh( kollDiv[11])" , 15 );
        setInterval( "vdoh( kollDiv[12])" , 15 );
        setInterval( "vdoh( kollDiv[13])" , 15 );
        setInterval( "vdoh( kollDiv[14])" , 15 );
        setInterval( "vdoh( kollDiv[15])" , 15 );
        setInterval( "vdoh( kollDiv[16])" , 15 );
        setInterval( "vdoh( kollDiv[17])" , 15 );
        setInterval( "vdoh( kollDiv[18])" , 15 );
        setInterval( "vdoh( kollDiv[19])" , 15 );
        setInterval( "vdoh( kollDiv[20])" , 15 );
        setInterval( "vdoh( kollDiv[21])" , 15 );
        setInterval( "vdoh( kollDiv[22])" , 15 );
        setInterval( "vdoh( kollDiv[23])" , 15 );
        setInterval( "vdoh( kollDiv[24])" , 15 );
        setInterval( "vdoh( kollDiv[25])" , 15 );
        setInterval( "vdoh( kollDiv[26])" , 15 );
        setInterval( "vdoh( kollDiv[27])" , 15 );
        setInterval( "vdoh( kollDiv[28])" , 15 );
        setInterval( "vdoh( kollDiv[29])" , 15 );
        setInterval( "vdoh( kollDiv[30])" , 15 );
Спасибо всем кто заинтересуется данным вопросам..
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.10.2014, 15:14
Ответы с готовыми решениями:

setInterval
Добрый вечер! помогите разобраться function func_isl(one){ var perem1 = one; $.post('isled.php', {x0:perem1}, function(data){ ...

setInterval не работает
Ну почему этот маленький зелёненький квадратик не хочет опускаться в низ? Я уже головой об стенку начинаю биться. <div...

не работает setInterval
Выдает Uncaught SyntaxError: Unexpected identifier подскажите что не так var timer = setInterval( function() { ...

5
Модератор
 Аватар для Thisman
771 / 352 / 142
Регистрация: 17.07.2013
Сообщений: 992
04.10.2014, 19:09
Цитата Сообщение от WeMeSder Посмотреть сообщение
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
 setInterval( "vdoh( kollDiv[0])" , 15 );
 setInterval( "vdoh( kollDiv[1])" , 15 );
 setInterval( "vdoh( kollDiv[2])" , 15 );
 setInterval( "vdoh( kollDiv[3])" , 15 );
 setInterval( "vdoh( kollDiv[4])" , 15 );
 setInterval( "vdoh( kollDiv[5])" , 15 );
 setInterval( "vdoh( kollDiv[6])" , 15 );
 setInterval( "vdoh( kollDiv[7])" , 15 );
 setInterval( "vdoh( kollDiv[8])" , 15 );
 setInterval( "vdoh( kollDiv[9])" , 15 );
 setInterval( "vdoh( kollDiv[10])" , 15 );
 setInterval( "vdoh( kollDiv[11])" , 15 );
//...
МАТЬ МОЯ ЖЕНЩИНА Начнем по порядку
0
Модератор
Эксперт JS
 Аватар для Eva Rosalene
5241 / 2115 / 416
Регистрация: 06.01.2013
Сообщений: 4,846
04.10.2014, 19:16

Не по теме:

Боже мой :swoon:


JavaScript
1
2
3
4
5
for (var i = 0; i < 31; ++i) setInterval((function (item){
   return (function (){
      vdoh(item);
   });
})(kollDiv[i]), 15);
Это если сохранять логику Вашего кода.

А вообще гораздо лучше поставить одну функцию в интервал, которая будет вызывать все остальные.
JavaScript
1
2
3
setInterval(function (){
   for (var i = 0; i < 31; ++i) vdoh(kollDiv[i]);
}, 15);
0
32 / 31 / 21
Регистрация: 13.07.2014
Сообщений: 374
04.10.2014, 19:31  [ТС]
Цитата Сообщение от FraidZZ Посмотреть сообщение
1
2
3
setInterval(function (){
* *for (var i = 0; i < 31; ++i) vdoh(kollDiv[i]);
}, 15);
Да, этот вариант замечательный. Спасибо за кусочек опыта.
0
Модератор
 Аватар для Thisman
771 / 352 / 142
Регистрация: 17.07.2013
Сообщений: 992
04.10.2014, 19:37
Цитата Сообщение от WeMeSder Посмотреть сообщение
"klone()"
Правильно писать clone.

Рассмотрим функцию klo... clone:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
function klone () {
            robotNameIndex++;
            
            kollDiv[indexKoll] = document.body.appendChild(document.createElement( "div" ));
            
            var nameAttr1 = document.createAttribute( 'id' ); // создаем атрибут
            nameAttr1.value = "r" + robotNameIndex;  // устанавливаем значение
            kollDiv[indexKoll].attributes.setNamedItem( nameAttr1 ); // привязываем атрибут
            
            var nameAttr1 = document.createAttribute( 'style' ); // создаем атрибут
            nameAttr1.value = "top:400px;left:400px;";  // устанавливаем значение
            kollDiv[indexKoll].attributes.setNamedItem( nameAttr1 ); // привязываем атрибут
            
            indexKoll++;
            ser++
            starter();
            //-----------------------------------------------..............
                    if( kollDiv.length > 24 ) {
                    clearInterval( kl )
                    }
        }
Как я понял функция, добавляет div с некоторыми атрибутами. Я сделаю это за n строчек :

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
function createEl(opt) {
    var tag = opt.tag || "div";
    var id = opt.id || "";
    var parent = opt.parent || document.body;
    var style = opt.style || {};
 
    var el = document.createElement(tag);
    el.id = id;
    parent.appendChild(el);
 
    for(var i in style) {
        el.style[i] = style[i];
    }
}
Называть clone передумал, ибо она не клонирует, а создает элемент. Используем вот так вот:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
var robotNameIndex = 0;
var kollDiv = [];
var indexKoll = 0;
var ser = -1;
var interr;
var timer = setInterval(function () {
    indexKoll++;
    var el = createEl({
        tag:'div',
        id:"r" + ndexKoll,
        style :{
            /* тут стиль */
            width:"100px",
            height:"100px",
            background : "black"
        } 
    })
    kollDiv.push(el);
    ser++;
    //starter(); закоментил ибо еще не дошли
    if(indexKoll > 5) clearInterval(timer);
},1000)
Добавлено через 3 минуты
WeMeSder, Не совсем понятно ,что делает функция vdoh,посмотреть бы ее код
1
32 / 31 / 21
Регистрация: 13.07.2014
Сообщений: 374
16.12.2014, 21:00  [ТС]
Функция vdoh делает лишь хаотичное движения div- ов по стр.
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
        function vdoh( namOb ) {
        
            var i1 = Math.round( Math.random() * 1 );
            var i2 = Math.round( Math.random() * 1 );
            w = namOb.offsetTop;
            g = namOb.offsetLeft;
                if( i1 == 0 && (document.body.clientHeight) - 10 > w ) {
                    w++;
                }
                if( i1 == 1 && w > krai ) {
                    w--;
                }
                if( i2 == 0 && (document.body.clientWidth) - 10 > g ) {
                    g++;
                }
                if( i2 == 1 && g > krai ) {
                    g--;
                }
            namOb.style.left = g;
            namOb.style.top = w; }
Но еща идея была в том что бы собрать div - ы в один общий, размера - "на сколько хватит" из всех имеющихся

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
        function zbor() {
            var koorX = kollDiv[0].offsetTop;
            var koorY = kollDiv[0].offsetLeft;
                for( i = 1; i < kollDiv.length; i++ ) {
                    kollDiv[i].style.background = "blue";
                    var positionX = kollDiv[i].offsetTop;
                    var positionY = kollDiv[i].offsetLeft;
                    
        //---------------------
        
        
        
        
                        if( i%4 == 0 ) {
                            sdT++;
                        }
                        if( i%4 == 1 ) {
                            sdU++;
                        }
                        if( i%4 == 2 ) {
                            sdT--;
                        }
                        if( i%4 == 3 ) {
                            sdU--;
                        }
                        
                        
                        if( 0 == 0 ) {
                                if( koorX < positionX + sdR * sdT ) {
                                    positionX--;
                                }
                                if( koorX > positionX + sdR * sdT ) {
                                    positionX++;
                                }
                                if( koorY < positionY + sdR * sdU ) {
                                    positionY--;
                                }
                                if( koorY > positionY + sdR * sdU ) {
                                    positionY++;
                                }
                        }
                            
 
                        
            //------------------------          
                    kollDiv[i].style.left = positionY;
                    kollDiv[i].style.top = positionX;
                }
                blocker++;
                sdU = 0;
                sdT = 0;
                krai = 10;
        }
- здесь размером 2x2 а нужно n x n -?

(<style> div{height:10px;width:10px;background-color:green;position:absolute;} </style>)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.12.2014, 21:00
Помогаю со студенческими работами здесь

SetInterval остановка
Как остановить таймер, когда выполнится какое-то условие? То есть, сначала setInterval выполняет свои функции, потом условие выполнилось,...

Сброс setInterval
Как сбросить заданный setInterval ? Есть ли нативные средства? Я по крайней мере таковых не нашел. Есть ли у кого готовые решения или...

SetInterval ,2 функции
Не получается сделать бесконечное выполнение двух функции ,с задержкой. Весь код не вижу смысла выкладывать. Есть две функции cvet() и...

Не работает setInterval
Здравствуйте var idb; var asd = 0; $(&quot;.button&quot;).mouseenter(function() { idb = $(this).attr('id'); var ...

Не работает setInterval();
Подскажите, пожалуйста, почему код не перезапускается каждые 300 мс? &lt;title&gt;DOM elements&lt;/title&gt; &lt;body&gt; ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru