2013-02-26 138 views
1

我使用anythingslider和colorbox来创建一种水平滑动页面,这是一种电子书。我已经在anythingslider中实现了'nav(to)'函数来构建导航,这在Firefox和Safari中非常有用,但不是IE8。令人沮丧的是,滑块部分仍然有效 - 它会左右移动,导航不能直接跳转到“页面”(实际上是一个列表项)。我怀疑有些挑剔的语法片断被IE8拒绝,但我无法找到它来挽救我的生命。Javascript导航无法在IE8中工作

为了充分披露,本页面的代码最初是使用in5创建的,它将InDesign文档转换为HTML。这是一个马虎,并没有做我想要的所有东西,所以我已经手动编码它约两个星期来调整它(事实上,它花了两个星期应该解释为什么我不知道什么是错的。如果不清楚,我是一个总菜鸟)。

我已经遍寻全部的答案,包括stackoverflow,github和csstricks。我无法找到任何有我的特定问题的人,并且为类似问题提供的答案是我已经完成或者没有实现的事情。我修改了元标记以解释IE8。我已经美化了javascript文件,所以我可以准确地找到导航在外部.js文件中定义的位置(并且我发现了它,但是我不足以完全理解我正在查看的JavaScript程序员)。

所以这里的代码:

<!DOCTYPE html> 
<html> 

<head> 
<meta charset="utf-8"> 
<title>BestBrands2013</title> 
<meta http-equiv="X-UA-Compatible" content="IE=8"> 

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.min.js"></script> 
<script>window.jQuery || document.write('<script src="assets/js/jquery.min.js"><\/script>')</script> 
<script type="text/javascript" src="assets/js/jquery.touchSwipe.min.js"></script> 
<script type="text/javascript" src="assets/js/jquery.anythingslider.min.js"></script> 
<script type="text/javascript" src="assets/js/jquery.colorbox-min.js"></script> 
<link rel="stylesheet" href="assets/css/theme-minimalist-square.css"> 
<link rel="stylesheet" href="assets/css/pages.css"> 


<script type="text/javascript" > 
var touchEnabled = 'ontouchstart' in document.documentElement; 
var useSwipe = 1; 
var pageMode = 'h'; 
var nav; 

$(function(){ 

    if($.colorbox) { 
     $('.lightbox').colorbox({iframe:true, width:"80%", height:"80%"}); 
     $('.thumb').colorbox({maxWidth:"85%", maxHeight:"85%"}); 
    } 
    $('img').bind('dragstart', function(event) { event.preventDefault(); }); 
    $('.pageItem').each(function(){ 
     if($(this).is('[onclick]')){ 
      if(touchEnabled) { 
       //this.setAttribute('touchstart', this.getAttribute('onclick')); 
       //this.removeAttribute('onclick'); 
      } else this.style.cursor = 'pointer'; 
     } 
    }); 
    if($.hasOwnProperty('scrollTo')){ 
    nav = { numPages:$('.pages .page').length, 
     back:function(ref){var targ=$(ref).parent('.page').prev()[0]; if(targ!=undefined); $.scrollTo(targ, 500);}, 
     next:function(ref){var targ=$(ref).parent('.page').next()[0]; if(targ!=undefined); $.scrollTo(targ, 500);}, 
     first:function(){$.scrollTo($('.page')[0], 500)}, 
     last:function(){$.scrollTo($('.page')[nav.numPages-1], 500)}, 
     to:function(n){$.scrollTo($('.page')[n-1], 500)} }; 
    } 
    var playvid = function(slider) { 
var vid = slider.$currentPage.find('video'); 
if (vid.length) { 
    // autoplay 
    vid[0].play(); 
} 
}; 
      var sliderSettings = { 
     mode: pageMode, 
     theme: 'minimalist-square', 
     buildArrows: (!touchEnabled && 1), 
     buildNavigation: false, 
     buildStartStop: false, 
     hashTags: false, 
     infiniteSlides: false, 
     stopAtEnd: true, 
     onInitialized: function(e, slider) { 
      playvid(slider); 
      nav = { 
       numPages:slider.pages, 
       current:slider.currentPage, 
       next:function(){slider.goForward();}, 
       back:function(){slider.goBack();}, 
       first:function(){this.to(1);}, 
       last:function(){this.to(this.numPages)}, 
       to:function(n){slider.gotoPage(n);} 
      }; 
      if(useSwipe) { 
      var container = $('#container'); 
      var vertMode = (pageMode.substr(0,1) == "v"); 
      container.swipe({ 
       swipe:function(event, direction, distance, duration, fingerCount) { 
        switch(direction) { 
         case "left": 
          if(!vertMode) nav.next(); 
          break; 
         case "right": 
          if(!vertMode) nav.back(); 
          break; 
         case "up": 
          if(vertMode) nav.next(); 
          break; 
         case "down": 
          if(vertMode) nav.back(); 
          break;  
        } 
       } 
      }); 
      } 
     }, 

    } 

    $('#slider').anythingSlider(sliderSettings); 
}); 
</script> 

</head> 

<body>  
<div id="container"> 
<ul class="pages" id="slider"> 

<li class="page"> 
    <img class="pageItem" src="assets/images/item_16.png" alt="page item"/> 
    <a href = "javascript:void(0)" onclick = "document.getElementById('popclinique').style.display='block';document.getElementById('fade').style.display='block'"> 
    <img class="pageItem" src="assets/images/item_17.png" style="left:165px; top:116px; " alt="page item"/> 
    </a> 
    <a href="https://shop.aafes.com/shop/default.aspx?loc=department.aspx%7Edept_id%3D8520&cm_sp=ebook-_-30513-_-bb_p2_clinique_sun" target="_blank"><img class="pageItem" src="assets/images/item_18.png" style="left:85px; top:381px; " alt="Clinique Sun"/></a> 
    <a href = "javascript:void(0)" onclick = "document.getElementById('popmilstar').style.display='block';document.getElementById('fade').style.display='block'"> 
    <img class="pageItem" src="assets/images/item_19.png" style="left:38px; top:567px; " alt="page item"/> 
</a> 
<a href="https://shop.aafes.com/shop/default.aspx?loc=department.aspx%7Edept_id%3D8517&cm_sp=ebook-_-30513-_-bb_p2_clinique_fragrance" target="_blank"><img class="pageItem" src="assets/images/item_20.png" style="left:271px; top:210px; " alt="Clinique Fragrance"/></a> 
<a href="https://shop.aafes.com/shop/default.aspx?loc=department.aspx%7Edept_id%3D8523&cm_sp=ebook-_-30513-_-bb_p2_clinique_mens" target="_blank"><img class="pageItem" src="assets/images/item_21.png" style="left:436px; top:207px; " alt="Clinique Mens"/></a> 
<a href="https://shop.aafes.com/shop/default.aspx?loc=department.aspx%7Edept_id%3D8501&cm_sp=ebook-_-30513-_-bb_p2_clinique_3step" target="_blank"><img class="pageItem" src="assets/images/item_22.png" style="left:591px; top:318px; " alt="Clinique 3 Step"/></a> 
<a href="https://shop.aafes.com/shop/default.aspx?loc=department.aspx%7Edept_id%3D8512&cm_sp=ebook-_-30513-_-bb_p2_clinique_makeup" target="_blank"><img class="pageItem" src="assets/images/item_23.png" style="left:864px; top:350px; " alt="Clinique Makeup"/></a> 
<a href="https://shop.aafes.com/shop/default.aspx?loc=department.aspx%7Edept_id%3D8505&cm_sp=ebook-_-30513-_-bb_p2_clinique_skincare" target="_blank"><img class="pageItem" src="assets/images/item_24.png" style="left:696px; top:47px; " alt="Clinique Skin Care"/></a> 
<button class="pageItem" style="left:217px; top:641px; " alt="clinique 11" id="item26" onclick="nav.to(2);">&nbsp;</button> 
<button class="pageItem" style="left:271px; top:641px; " alt="nikebutton 11" id="item27" onclick="nav.to(3);">&nbsp;</button> 
<button class="pageItem" style="left:325px; top:641px; " alt="underarmourbuttpn 11" id="item28" onclick="nav.to(4);">&nbsp;</button> 
<button class="pageItem" style="left:379px; top:641px; " alt="coachbutton 11" id="item29" onclick="nav.to(5);">&nbsp;</button> 
<button class="pageItem" style="left:433px; top:641px; " alt="fossilbutton 11" id="item30" onclick="nav.to(6);">&nbsp;</button> 
<button class="pageItem" style="left:487px; top:641px; " alt="keurigbutton 11" id="item31" onclick="nav.to(7);">&nbsp;</button> 
<button class="pageItem" style="left:541px; top:641px; " alt="dellbutton 11" id="item32" onclick="nav.to(8);">&nbsp;</button> 
<button class="pageItem" style="left:595px; top:641px; " alt="applebutton 11" id="item33" onclick="nav.to(9);">&nbsp;</button> 
<button class="pageItem" style="left:649px; top:641px; " alt="dysonbutton 11" id="item34" onclick="nav.to(10);">&nbsp;</button> 
<button class="pageItem" style="left:703px; top:641px; " alt="samsungbutton 11" id="item35" onclick="nav.to(11);">&nbsp;</button> 
<button class="pageItem" style="left:757px; top:641px; " alt="knmorebutton 11" id="item36" onclick="nav.to(12);">&nbsp;</button> 
<img class="pageItem" src="assets/images/item_25.png" style="left:16px; top:12px; " alt="page item"/> 
</li> 
</body> 

我已经缩写了很多 - 整个事情是极大的相 - 那不过是整个头部。我只包含一个'页面'(实际上是一个列表项目)。相关位是onclick =“nav.to(n);”在最后的按钮处,以及靠近头部尾部的滑块设置脚本块中的导航定义。

我知道每个人都可能有实际的编程问题需要回答,而我的软编程工作对您的优先级列表很低,但我正拼命地尽我所能地学习这些东西,并且会完全感谢任何人的帮助可以提供。

回答

0

朝脚本块的末尾添加逗号。由于这些原因,IE8因破解而臭名昭着。

   } 
      } 
     }); 
     } 
    }, <-- here 

} 
+0

谢谢!我试图清理它,但错过了那一个。不幸的是,这并没有解决它。我得到的错误(我之前应该提到)是'nav是null或不是对象。'这是令人惊讶的,因为我很确定这是宣布的。 – InfinityMax 2013-02-26 16:08:07

+0

我继续前进,并打上了这个绿色的对号。大量的进一步测试让我相信这个问题是由我的工作防火墙引起的,因为这种防火墙会将很多IE禁用为安全措施。我没有尝试解决政府繁文by节的拜占庭式迷宫问题,而是编写了条件IE样式表,将导航显示设置为“无”,从而完全消除了问题。它适用于不是IE的每台计算机。 – InfinityMax 2013-02-26 17:06:33