【问题标题】:Change CSS style from javascript?从javascript更改CSS样式?
【发布时间】:2011-02-16 04:16:03
【问题描述】:

为了简单起见,我不想使用 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>

【问题讨论】:

  • 这可能与运行 javascript 后页面加载和呈现 CSS 有关。这可能取决于浏览器。希望不要。
  • document.getElementById("wrap").style.width = "1390px";
  • 另外,不要使用内联javascript将其包含在文件中。

标签: javascript html css iframe


【解决方案1】:

您需要 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;
}      

【讨论】:

  • 谢谢。有谁知道为什么它会在放大 2 倍时进入谷歌。然后它以 0.5 倍的速度进入雅虎,然后以 0.5 倍的变焦进入 ebay。理想情况下,它是 2 倍的谷歌,10 倍的雅虎,然后是 0.5 倍的 ebay。谢谢
【解决方案2】:

您的 switch 语句失败了,因为它在每个 case 的末尾缺少 break 语句。没有break,正确的情况和它下面的任何情况都会执行。这就是为什么“只有第三个有效”

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2016-11-09
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-10-12
    相关资源
    最近更新 更多