Это самый второй самый простой эффект опрокидывания, но я не нашел простого решения.
Требуется: У меня есть список элементов и список соответствия слайдов (DIV). После загрузки следует выбрать первый элемент списка (полужирный), и первый слайд должен быть видимым. Когда пользователь наводится на другой элемент списка, этот элемент списка должен быть выбран, а соответствующий слайд будет показан.
Следующий код работает, но ужасно. Как я могу получить это поведение элегантным способом? jquery имеет десятки анимированных и сложных эффектов опрокидывания, но я не придумал чистый способ для этого эффекта.
<script type="text/javascript">
function switchTo(id) {
document.getElementById('slide1').style.display=(id==1)?'block':'none';
document.getElementById('slide2').style.display=(id==2)?'block':'none';
document.getElementById('slide3').style.display=(id==3)?'block':'none';
document.getElementById('slide4').style.display=(id==4)?'block':'none';
document.getElementById('switch1').style.fontWeight=(id==1)?'bold':'normal';
document.getElementById('switch2').style.fontWeight=(id==2)?'bold':'normal';
document.getElementById('switch3').style.fontWeight=(id==3)?'bold':'normal';
document.getElementById('switch4').style.fontWeight=(id==4)?'bold':'normal';
}
</script>
<ul id="switches">
<li id="switch1" onmouseover="switchTo(1);" style="font-weight:bold;">First slide</li>
<li id="switch2" onmouseover="switchTo(2);">Second slide</li>
<li id="switch3" onmouseover="switchTo(3);">Third slide</li>
<li id="switch4" onmouseover="switchTo(4);">Fourth slide</li>
</ul>
<div id="slides">
<div id="slide1">Well well.</div>
<div id="slide2" style="display:none;">Oh no!</div>
<div id="slide3" style="display:none;">You again?</div>
<div id="slide4" style="display:none;">I'm gone!</div>
</div>