0

我正在使用引导程序进行构建,并且有一个标题区域可以在左侧旋转文本,并利用引导程序的轮播在右侧旋转图像。正文只有几个字的抄袭,主字较大,有文字,下面有几个字,字型不同。我正在使用的 javascript 会旋转第一个大词,但会将其他词堆叠在一起。在大多数浏览器中一切正常,但 IE8 给了我这个问题。

任何人都可以查看我的代码并帮助我解决这个问题吗?

这是我的html:

<div class="rotator">
   <ul>
      <li class="show">

         <p class="script">Discover<br/><br/>
         <span class="captionwhite">the many uses<br/>of glass block</span></p>
      </li>

      <li class="show">

         <p class="script">Create<br/><br/>
         <span class="captionwhite">a beautiful<br/>shower enclosure</span></p>
      </li>

      <li class="show">

          <p class="script">Illuminate<br/><br/>
          <span class="captionwhite"> your bathroom<br/>naturally</span></p>
       </li>
     </ul>
   </div>

这是我的CSS:

/* rotator in-page placement */
    div.rotator {       
    position:relative;

}
/* rotator css */
    div.rotator ul li {
    position:absolute;
    list-style: none;
}

这是javascript:

function theRotator() {
    //Set the opacity of all images to 0
    $('div.rotator ul li').css({opacity: 0.0});

    //Get the first image and display it (gets set to full opacity)
    $('div.rotator ul li:first').css({opacity: 1.0});

    //Call the rotator function to run the slideshow, 3000 = change to next image after 3 seconds

    setInterval('rotate()',3000);

}

function rotate() { 
    //Get the first image
    var current = ($('div.rotator ul li.show')?  $('div.rotator ul li.show') : $('div.rotator ul li:first'));

    if ( current.length == 0 ) current = $('div.rotator ul li:first');

    //Get next image, when it reaches the end, rotate it back to the first image
    var next = ((current.next().length) ? ((current.next().hasClass('show')) ? $('div.rotator ul li:first') :current.next()) : $('div.rotator ul li:first'));

    //Un-comment the 3 lines below to get the images in random order

    //var sibs = current.siblings();
    //var rndNum = Math.floor(Math.random() * sibs.length );
    //var next = $( sibs[ rndNum ] );


    //Set the fade in effect for the next image, the show class has higher z-index
    next.css({opacity: 0.0})
    .addClass('show')
    .animate({opacity: 1.0}, 3000);

    //Hide the current image
    current.animate({opacity: 0.0}, 3000)
    .removeClass('show');

};



$(document).ready(function() {      
    //Load the slideshow
    theRotator();
    $('div.rotator').fadeIn(3000);
    $('div.rotator ul li').fadeIn(3000); // tweek for IE
});

任何帮助,将不胜感激!

4

1 回答 1

0

从我的评论:

IE8 不支持CSS不透明度规则。您必须为此使用专有的Microsoft 过滤规则(仅适用于 IE 浏览器)。或者,更容易的是,使用 jQuery 的 .hide() 或设置 CSS 规则 display: none;。

在查看了更多代码之后,最好的选择可能是使用一些 jQuery 的内置函数。您需要使用几个 jQuery 选项之一替换大部分opacity用法(通过使用.css().animate()),具体取决于您对opacity设置所做的操作。

对于.css({opacity: 0.0})(立即隐藏东西),您应该改用.hide()

myElement.hide();

对于.css({opacity: 1.0})(立即显示的东西),您应该改用.show()

myElement.show();

对于.animate()使用的调用opacity(缓慢显示或隐藏),您应该使用.fadeIn()and .fadeOut()。您似乎已经.fadeIn()在 J​​S 代码的底部使用了 IE 调整。您可以以与您相同的方式使用它.animate({opacity: 1.0}, 3000),只需使用它即可.fadeIn(3000).fadeOut(3000)代替.animate({opacity: 0.0}, 3000). _ 如果您没有明确传递持续时间的数字,则默认持续时间在.fadeIn().fadeOut()和上都是相同的。.animate()400

jQuery 函数链接到 jQuery API 文档,您可以在这些页面中找到完整的使用文档和示例。

如果您在 IE8 中使用.fadeIn()or时遇到问题.fadeOut()这个问题可能会有所帮助。

于 2013-09-27T18:11:28.830 回答