2012-04-14 15 views
0

Was ist falsch in diesem Code?Was ist falsch in diesem Javascript-Code?

function FloatMenu() { 
    var scrollAmount = $(document).scrollTop(); 
    var newPosition = menuPosition + scrollAmount; 

    if ($(window).height() < $fl_menu.height() + $fl_menu_menu.height()) { 

     $fl_menu.css("top", menuPosition); 

    } else { 

     $fl_menu.stop().animate({ 
      top: newPosition 
     }, $float_speed, $float_easing); 

    } 
}​ 

Der vollständige Code:

/* Floating Menu */ 
//config 
$float_speed=500; //milliseconds 
$float_easing="easeOutQuint"; 
$menu_fade_speed=500; //milliseconds 
$closed_menu_opacity=0.75; 

//cache vars 
$fl_menu=$("#fl_menu"); 
$fl_menu_menu=$("#fl_menu .menu"); 
$fl_menu_label=$("#fl_menu .label"); 

$(window).load(function() { 
    menuPosition=$('#fl_menu').position().top; 
    FloatMenu(); 
    $fl_menu.hover(
     function(){ //mouse over 
      $fl_menu_label.fadeTo($menu_fade_speed, 1); 
      $fl_menu_menu.fadeIn($menu_fade_speed); 
     }, 
     function(){ //mouse out 
      $fl_menu_label.fadeTo($menu_fade_speed, $closed_menu_opacity); 
      $fl_menu_menu.fadeOut($menu_fade_speed); 
     } 
    ); 
}); 

$(window).scroll(function() { 
    FloatMenu(); 
}); 

function FloatMenu(){ 
    var scrollAmount=$(document).scrollTop(); 
    var newPosition=menuPosition+scrollAmount; 
    if($(window).height()<$fl_menu.height()+$fl_menu_menu.height()){ 
     $fl_menu.css("top",menuPosition); 
    } else { 
     $fl_menu.stop().animate({top: newPosition}, $float_speed, $float_easing); 
    } 
}      

Fehler sind:

Message: 'menuPosition' is undefined 

und

Message:'position().top' is null or not an object 
+0

haben Sie HTML, um es zu sichern? – Asdfg

+0

müssen Sie auch nicht wie $ menuPosition schreiben? – Asdfg

+0

@OriginalSyn: Ich dachte, es wäre PHP-Syntax, um die JS-Variable zu deklarieren. Vergiss es. Es sieht so aus, als wäre menuPosition nicht im Code definiert – Asdfg

Antwort

0

versuchen menuPosition außerhalb der Bereiche der Funktion erklärt:

var menuPosition = 0; // declared outside of function scopes 

/* Floating Menu */ 
//config 
$float_speed=500; //milliseconds 
$float_easing="easeOutQuint"; 
$menu_fade_speed=500; //milliseconds 
$closed_menu_opacity=0.75; 

//cache vars 
$fl_menu=$("#fl_menu"); 
$fl_menu_menu=$("#fl_menu .menu"); 
$fl_menu_label=$("#fl_menu .label"); 

$(window).load(function() { 
    menuPosition=$('#fl_menu').position().top; 
    FloatMenu(); 
    $fl_menu.hover(
     function(){ //mouse over 
      $fl_menu_label.fadeTo($menu_fade_speed, 1); 
      $fl_menu_menu.fadeIn($menu_fade_speed); 
     }, 
     function(){ //mouse out 
      $fl_menu_label.fadeTo($menu_fade_speed, $closed_menu_opacity); 
      $fl_menu_menu.fadeOut($menu_fade_speed); 
     } 
    ); 
}); 

$(window).scroll(function() { 
    FloatMenu(); 
}); 

function FloatMenu(){ 
    var scrollAmount=$(document).scrollTop(); 
    var newPosition=menuPosition+scrollAmount; 
    if($(window).height()<$fl_menu.height()+$fl_menu_menu.height()){ 
     $fl_menu.css("top",menuPosition); 
    } else { 
     $fl_menu.stop().animate({top: newPosition}, $float_speed, $float_easing); 
    } 
} 
+0

Der erste Fehler wurde behoben (Nachricht: 'menuPosition' ist nicht definiert) Letzteres wird jedoch nicht aufgelöst (Nachricht: 'position(). Top' ist null oder kein Objekt) – inmoon

+0

Probiere $ fl_menu statt $ ('# fl_menu') – Joe

0

Verwenden Sie ein Argument in Ihrer Funktion. Es wird Ihr Problem elegant beheben.

function FloatMenu(menuPosition) { 
    // Write your code as usual 
} 

// I guess you meant $(document).ready instead of $(window).load ? 
// The main difference is that $(window).load will wait for all the images to be fully loaded, for example 
$(document).ready(function() { 
    menuPosition=$('#fl_menu').position().top; 
    // Since you're using an argument, pass it! 
    FloatMenu(menuPosition); 

    // Or you can reduce to: 
    FloatMenu($('#fl_menu').position().top)