2010-01-16 9 views
1

Je construis une page qui utilise plusieurs éléments javascript différents et je semble avoir rencontré un problème que je n'ai pas avant (pas étonnant que je suis nouveau à javascript).Coda Slider Problème - Fonctionne dans Firefox, pas Chrome/Safari

J'ai implémenté le tutoriel pour le curseur JQuery Coda situé ici: http://jqueryfordesigners.com/coda-slider-effect/.

Il semble que l'effet de glissement fonctionne quand je l'exécute Firefox mais pas Chrome ou Safari. Vous vous demandez si c'est un problème commun et si je manque quelque chose d'évident. Pour aider, je joins le code de la page sur laquelle je travaille car cela peut vous aider à comprendre les scripts que j'utilise.

<head> 
    <title></title> 

    <link rel="stylesheet" href="stylesheets/style.css" media="screen" /> 

    <script src="js/jquery-1.3.2.min.js" type="text/javascript"></script> 
    <script type="text/javascript" src="http://cloud.github.com/downloads/malsup/cycle/jquery.cycle.all.2.73.js"></script> 
    <script src= "js/banner.js"type="text/javascript"></script> 
    <script src="js/menu.js" type="text/javascript"></script> 
    <script src="js/jquery.localscroll-1.2.7-min.js" type="text/javascript"></script> 
    <script src="js/jquery.scrollTo-1.4.2-min.js" type="text/javascript"></script> 
    <script src="js/jquery.serialScroll-1.2.2-min.js" type="text/javascript"></script> 
    <script src="js/slider.js" type="text/javascript"></script> 

</head> 

EDIT: slider.js

// when the DOM is ready... 
$(document).ready(function() { 

var $panels = $('#slider .scrollContainer > div'); 
var $container = $('#slider .scrollContainer'); 

// if false, we'll float all the panels left and fix the width 
// of the container 
var horizontal = true; 

// float the panels left if we're going horizontal 
if (horizontal) { 
    $panels.css({ 
    'float' : 'left', 
    'position' : 'relative' // IE fix to ensure overflow is hidden 
    }); 

    // calculate a new width for the container (so it holds all panels) 
    $container.css('width', $panels[0].offsetWidth * $panels.length); 
} 

// collect the scroll object, at the same time apply the hidden overflow 
// to remove the default scrollbars that will appear 
var $scroll = $('#slider .scroll').css('overflow', 'hidden'); 

// apply our left + right buttons 
$scroll 
    .before('<img class="scrollButtons left" src="images/scroll_left.png" />') 
    .after('<img class="scrollButtons right" src="images/scroll_right.png" />'); 

// handle nav selection 
function selectNav() { 
    $(this) 
    .parents('ul:first') 
     .find('a') 
     .removeClass('selected') 
     .end() 
    .end() 
    .addClass('selected'); 
} 

$('#slider .navigation').find('a').click(selectNav); 

// go find the navigation link that has this target and select the nav 
function trigger(data) { 
    var el = $('#slider .navigation').find('a[href$="' + data.id + '"]').get(0); 
    selectNav.call(el); 
} 

if (window.location.hash) { 
    trigger({ id : window.location.hash.substr(1) }); 
} else { 
    $('ul.navigation a:first').click(); 
} 

// offset is used to move to *exactly* the right place, since I'm using 
// padding on my example, I need to subtract the amount of padding to 
// the offset. Try removing this to get a good idea of the effect 
var offset = parseInt((horizontal ? 
    $container.css('paddingTop') : 
    $container.css('paddingLeft')) 
    || 0) * -1; 


var scrollOptions = { 
    target: $scroll, // the element that has the overflow 

    // can be a selector which will be relative to the target 
    items: $panels, 

    navigation: '.navigation a', 

    // selectors are NOT relative to document, i.e. make sure they're unique 
    prev: 'img.left', 
    next: 'img.right', 

    // allow the scroll effect to run both directions 
    axis: 'xy', 

    onAfter: trigger, // our final callback 

    offset: offset, 

    // duration of the sliding effect 
    duration: 500, 

    // easing - can be used with the easing plugin: 
    // http://gsgd.co.uk/sandbox/jquery/easing/ 
    easing: 'swing' 
}; 

// apply serialScroll to the slider - we chose this plugin because it 
// supports// the indexed next and previous scroll along with hooking 
// in to our navigation. 
$('#slider').serialScroll(scrollOptions); 

// now apply localScroll to hook any other arbitrary links to trigger 
// the effect 
$.localScroll(scrollOptions); 

// finally, if the URL has a hash, move the slider in to position, 
// setting the duration to 1 because I don't want it to scroll in the 
// very first page load. We don't always need this, but it ensures 
// the positioning is absolutely spot on when the pages loads. 
scrollOptions.duration = 1; 
$.localScroll.hash(scrollOptions); 

}); 
+0

@bgadoci Ce qui est le plus important est le code jQuery réel qui implémente le curseur et se fixe les événements, etc. Pouvez-vous mettre cela? Peut-être grâce à un service comme http://pastie.org si c'est vraiment long. –

+0

@doug Je viens d'ajouter le code slider.js. Est-ce ce dont vous parlez? – bgadoci

+0

Yup! merci ... cela aidera à trouver une solution –

Répondre

0

Pourquoi ne pas vous venez de copier "http://jqueryfordesigners.com/demo/coda-slider.html" Sa réduction de ce que vous avez besoin. Rappelez-vous que vous avez besoin de ceux-ci:

<script src="jquery-1.2.6.js" type="text/javascript"></script> 
<script src="jquery.scrollTo-1.3.3.js" type="text/javascript"></script> 
<script src="jquery.localscroll-1.2.5.js" type="text/javascript" charset="utf-8"></script> 
<script src="jquery.serialScroll-1.2.1.js" type="text/javascript" charset="utf-8"></script> 
<script src="coda-slider.js" type="text/javascript" charset="utf-8"></script> 

Et le HTML devrait être similaire (voir la source pour le savoir). Cela fonctionne très bien dans Chrome.

+0

N'est-ce pas ce que j'ai? Je viens de copier les téléchargements les plus récents de JQuery et le nom du fichier de la série Scroll sur le lien principal. Qu'est-ce que je rate? – bgadoci

+0

Essayez de copier et coller http://jqueryfordesigners.com/demo/coda-slider.html il devrait fonctionner sur tous les navigateurs. Sans connaître votre code HTML ou votre échantillon réduit, vous ne savez pas quel est le problème auquel vous êtes confronté. Doit être quelque chose de petite erreur de syntaxe. Essayez de le valider. –

1

après des heures de recherche et de débogage, j'ai découvert la solution. jQuery s'infiltre avec joomla inclus mootools. Retirez-le avec le code suivant dans votre tête index.php:

<?php 
     //remove mootools.js and caption.js 
     $headerstuff=$this->getHeadData(); 
     reset($headerstuff['scripts']); 
     foreach($headerstuff['scripts'] as $key=>$value){ 
      unset($headerstuff['scripts'][$key]); 
     }  
     $this->setHeadData($headerstuff); 
     ?> 
Questions connexes