Diskuze: Ztučnění písma po určitém intervalu
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 6 zpráv z 6.
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.
Jaké výsledky přinesly funkce setTimeout či setInterval?
V JS som úplný začiatočník ale postupnými krokmi som sa dopracoval k
tomuto hádam tu budú iné
jednoduchšie a elegantnejšie spôsoby, ale zatiaľ aspoň niečo
<!DOCTYPE html>
<html>
<body>
<div id="divId">
aaa / bbb / ccc / ddd
</div>
<script>
var x = 0;
function start(){
setInterval(function () {return changeText(x++);}, 2000);
}
function changeText(index){
var words = getTextFromDiv().split("/");
var result = "";
for(var i = 0; i < words.length; i++){
if(i == index)
words[i] = "<b>" + words[i] + "</b>";
result += words[i];
if(i != words.length - 1)
result += "/";
}
document.getElementById("divId").innerHTML = result;
if(x == words.length){
x = 0;
}
}
//get text from element without HTML
function getTextFromDiv() {
var element = document.getElementById('divId');
return element.innerText || element.textContent;
}
start();
</script>
</body>
</html>
Já to dělal nějak takhle.
$(document).ready(function(i) {
for(var i=1;i<5;i++) {
$("#main-section-text-"+i).delay(i*1000).queue(function(){
$(this).addClass("foo").delay(5000).removeClass("foo");
});
}
})
Ale nemůžu přijít na to, proč mi nejde postupně odstranit tu třídu.
Byl bych rád za každou radu.
Já osobně bych to řešil asi nějak takto
<span data-index="0">Test</span> /
<span data-index="1">Baf</span> /
<span data-index="2">Chléb</span>
<script>
var currentIndex = 0;
var maxIndex = 2;
var interval = window.setInterval(function() {
$("span[data-index]").each(function() {
$(this).removeClass("foo");
});
$("span[data-index='" + currentIndex + "']").addClass("foo");
currentIndex++;
if (currentIndex > maxIndex) {
window.clearInterval(interval);
}
}, 2000);
</script>
To vypada jako docela zabavna vec.
<div id='wrapper'>
<span class='foo' data-index="0">Test</span> /
<span data-index="1">Baf</span> /
<span data-index="2">Chléb</span>
</div>
<script>
setInterval((wrapper => () => {
(selected => {
selected.removeAttribute('class');
(selected
.nextElementSibling || wrapper.firstElementChild).setAttribute('class', 'foo')
})(wrapper.querySelector('.foo'))
})(document.getElementById('wrapper')), 500);
</script>
Kod neberte vazne, jen pro pobaveni.
Vychazel jsem z reseni Martin Konečný (pavelco1998)
Zobrazeno 6 zpráv z 6.