⊗jsSpOtDm 277 of 294 menu

Оптимизација рада са DOM у JavaScript-у

Рад са DOM је спора операција. Зато треба свести на минимум добијање елемената, читање и упис података, посебно у петљи.

Хајде да погледамо на примеру. Рецимо да имамо унос поље, у које се уноси број:

<input>

Хајде да при губитку фокуса проверимо, да ли је унети број у задатом опсегу:

let input = document.querySelector('input'); input.addEventListener('blur', function() { if (+input.value > 0 && +input.value <= 10) { console.log('+++'); } else { console.log('---'); } });

Проблем је у томе што два пута читамо текст из унос поља, иако се број у њему не мења. То, наравно, није оптимално. Хајде да оптимизујемо:

let input = document.querySelector('input'); input.addEventListener('blur', function() { let num = +input.value; if (num > 0 && num <= 10) { console.log('+++'); } else { console.log('---'); } });

Следећи код проверује унесену вредност. Извршите оптимизацију:

<input> let input = document.querySelector('input'); input.addEventListener('blur', function() { if (input.value === '1' || input.value === '2') { console.log('+++'); } else { console.log('---'); } });

Следећи код тражи збир целих бројева од јединице до броја унетог у унос поље. Извршите оптимизацију:

<input> let input = document.querySelector('input'); input.addEventListener('blur', function() { let sum = 0; for (let i = 1; i <= +input.value; i++) { sum += i; } console.log(sum); });

Следећи код тражи збир делилаца броја унетог у унос поље. Извршите оптимизацију:

<input> <div></div> let input = document.querySelector('input'); input.addEventListener('blur', function() { let sum = 0; for (let i = 1; i <= +input.value; i++) { if (input.value % i === 0) { sum += i; let div = document.querySelector('div'); div.textContent = sum; } } });

Следећи код диже бројеве из пасуса на квадрат. Извршите оптимизацију:

<p>1</p> <p>2</p> <p>3</p> <p>4</p> let elems = document.querySelectorAll('p'); for (let elem of elems) { elem.textContent = elem.textContent * elem.textContent; }

Следећи код проверује да ли је у унос поље унети стринг дужине у задатом опсегу. Извршите оптимизацију:

<input data-min="5" data-max="10"> let inp = document.querySelector('input'); inp.addEventListener('blur', function() { if (inp.dataset.min > inp.value.length || inp.dataset.max < inp.value.length) { console.log('+++'); } else { console.log('---'); } });
Српски
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Користимо колачиће за рад сајта, аналитику и персонализацију. Обрада података се врши у складу са Политиком приватности.
прихвати све подеси одбиј