我不想仅仅为了简单而使用jquery。我有三个网站,其中一页循环。我希望每个网页都可以通过不同的标量值进行缩放。我尝试将一个类应用于每个页面,但是使用了switch语句,但它没有用,它只会保留在第三种样式上。我不关心效率,它只会翻滚三页,所以它可以硬编码。感谢
<style>
#wrap { width: 1390px; height: 690px; padding: 0; overflow: hidden; }
#frame.first { width: 1390px; height: 690px; border: 0px solid black; }
#frame.first { zoom: 2; -moz-transform: scale(2); -moz-transform-origin: 0 0; }
#frame.second { width: 1395px; height: 695px; border: 0px solid black; }
#frame.second { zoom: 4; -moz-transform: scale(1); -moz-transform-origin: 0 0; }
#frame.third { width: 1395px; height: 695px; border: 0px solid black; }
#frame.third { zoom: .5; -moz-transform: scale(1); -moz-transform-origin: 0 0; }
</style>
<script type="text/javascript">
var frames = Array('http://www.google.com, 5,
'http://www.yahoo.com', 5,
'http://www.ebay.com', 5);
var i = 0, len = frames.length;
function ChangeSrc()
{
if (i >= len) { i = 0; }
switch(i)
{
case 0:
document.getElementById('frame').className = 'first';
document.getElementById('frame').className
case 1:
document.getElementById('frame').className = 'second';
document.getElementById('frame').className
case 2:
document.getElementById('frame').className = 'third';
document.getElementById('frame').className
}
document.getElementById('frame').src = frames[i++];
setTimeout('ChangeSrc()', (frames[i++]*1000));
}
window.onload = ChangeSrc;
</script>
</head>
<body>
<div id="wrap">
<iframe src="" class="" id="frame" scrolling="no" frameborder="0"></iframe>
</div>
</body>
</html>
答案 0 :(得分:3)
您需要使用break语句来防止切换进入下一个语句。
switch(i)
{
case 0:
document.getElementById('frame').className = 'first';
break;
case 1:
document.getElementById('frame').className = 'second';
break;
case 2:
document.getElementById('frame').className = 'third';
break;
}
答案 1 :(得分:1)
您的switch语句失败,因为它在每个案例结尾都没有break
语句。如果没有break
,则会执行正确的案例及其下面的任何案例。这就是“只有第三个有效”的原因