There is one line in my jquery code not working after the document.ready function. The others do work.
The same line does work in a window.resize function. I hop you can help me: I added a comment after the line that is not working
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>
Made in 030
</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<link href="style.css" rel="stylesheet" media="all" type="text/css" />
<link href="//maxcdn.bootstrapcdn.com/font-awesome/4.2.0/css/font-awesome.min.css" rel="stylesheet">
<script src="http://code.jquery.com/jquery-latest.min.js" type="text/javascript"></script>
<script type="text/javascript">
$(document).ready(function(){
// hover
$(function() {
var $el, leftPos, newWidth,
$mainNav = $("menu ul");
$mainNav.append("<li id='magic-line'></li>");
var $magicLine = $("#magic-line");
$magicLine
.width($("menu ul li.active").width())
.css("left", $("menu ul li.active a").position().left)
.data("origLeft", $magicLine.position().left)
.data("origWidth", $magicLine.width());
$("menu ul li a").hover(function() {
$el = $(this);
leftPos = $el.position().left;
newWidth = $el.parent().width();
$magicLine.stop().animate({
left: leftPos,
width: newWidth
},500);
}, function() {
$magicLine.stop().animate({
left: $magicLine.data("origLeft"),
width: $magicLine.data("origWidth")
},500);
});
});
$('.menu_container').css('height',$('body').width()/11);
$('menu ul li a').css('font-size',$('body').width()/85);
$('#magic-line').css('margin-top',$('body').width()/11 - 10);//This line is not working
$('.logo img').css('height',$('body').width()/11-15);
$('.logo').css('height',$('body').width()/11);
var outerHeight = $('menu ul li').height();
var innerHeight = $('menu ul li a').height();
$('menu ul li a').css('margin-top', (outerHeight - innerHeight)/2);
var outerWidth = $('menu').width();
var innerWidth = $('.logo').width();
$('.logo_container').css('margin-left', (outerWidth - innerWidth)/2);
})
$(window).resize(function(){
$('.menu_container').css('height',$('body').width()/11);
$('menu ul li a').css('font-size',$('body').width()/85);
$('#magic-line').css('top',$('body').width()/11 - 10);
$('.logo img').css('height',$('body').width()/11-15);
$('.logo').css('height',$('body').width()/11);
var outerHeight = $('menu ul li').height();
var innerHeight = $('menu ul li a').height();
$('menu ul li a').css('margin-top', (outerHeight - innerHeight)/2);
var outerWidth = $('menu').width();
var innerWidth = $('.logo').width();
$('.logo_container').css('margin-left', (outerWidth - innerWidth)/2);
})
</script>
</head>
<body>
<header>
<div class="menu_container">
<menu>
<ul class="left_menu" >
<li class="left" ><a href="#">Home</a></li>
<li class="left" ><a href="#">Over</a></li>
<li class="left"><a href="#">Probeerlijst</a></li>
<li class="logo_container">
<div class="logo">
<img src="img/logo.png" alt=""/>
</div>
</li>
<li class="right active"><a href="#">Contact</a></li>
<li class="right"><a href="#">Shop</a></li>
<li class="right"><a href="#">Blog</a></li>
</ul>
</menu>
</div>
</header>
</body>
</html>