为了简单起见,我不想使用 jquery。我有三个网站,一页循环浏览。我希望每个网页都按不同的标量值进行缩放。我尝试将一个类应用到每个页面,但使用 switch 语句它应该在 google 上缩放 2x,在 yahoo 上缩放 4x,在 ebay 上缩放 .5x。但是,当我运行代码时,它将以 2 倍的缩放比例进入谷歌。然后它以 .5 倍的比例转到雅虎,然后以 0.5 倍的缩放比例转到 ebay。我不关心效率,它只会滚动三个页面,因此可以进行硬编码。谢谢
<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
break;
case 1:
document.getElementById('frame').className = 'second';
document.getElementById('frame').className
break;
case 2:
document.getElementById('frame').className = 'third';
document.getElementById('frame').className
break;
}
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>
最佳答案
您的变量不应命名为 frames。当您命名 var 框架时,您正在搞乱 window.frames。将其命名为其他名称。
在这里使用 for 循环是错误的,因为它不会给您任何时间来加载页面。您可能想使用 setTimeout调用每次迭代。
关于javascript - CSS 样式与 Javascript 不同步,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5029137/