jquery $('selector').css('top') renvoie des valeurs différentes pour IE, firefox et Chrome
Je suis à l'aide de jQuery $('selector').css('top') pour obtenir la valeur maximale pour vous aider à positionner les éléments dynamiques et je trouve que j'obtiens des résultats différents selon le navigateur.
si le sélecteur de style est défini sur haut:5%
Firefox renvoie 5%.
IE 7, 8, 9 retour d'une valeur de pixel qui change en fonction de la LARGEUR de l'écran du navigateur (wow).
Chrome renvoie 'auto'.
dans le test suivant, html,
firefox retourne:
m1 - 5%
m2 - 100%
m3 - 100px
IE 7, 8, 9 retourne:
m1 - 25px
m2 - 509px
m3 - 100px
et si j'élargir l'écran, c'est à dire retourne:
m1 - 49px
m2 - 977px
m3 - 100px
Chrome retourne:
m1 - auto
m2 - auto
m3 - auto
<!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>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.1/jquery.min.js"></script>
<style type="text/css">
#m1 {top:5%;}
#m2 {top:100%;}
#m3 {top:100px;}
</style>
<title>CSS Test</title>
</head>
<body>
<div class="m" id='m1'>m1</div>
<div class="m" id='m2'>m2</div>
<div class="m" id='m3'>m3</div>
<script type="text/javascript">
function get_css() {
var output = "";
$('.m').each(function(){
output += $(this).html() + ' - ' +$(this).css('top')+ "<br />";
});
$('#output').html(output);
}
</script>
<br /><input type='button' name='get_css' value="css('top')" onclick="get_css()"/>
<p><div id='output'></div></p>
</body>
</html>
- C'est de cette façon
.css
est prévu pour travailler. La question est de savoir quels résultats souhaitez-vous obtenir?
Vous devez vous connecter pour publier un commentaire.
Utilisation
$('selector').offset().top
pour obtenir la valeur numérique de latop
position..css()
renvoie la valeur CSS du haut-position, qui pourrait êtreauto
,1234px
, ou quelque chose de semblable, pas une méthode fiable pour obtenir la position supérieure.Voir aussi:
La chose est, aucun de vos éléments de test ont en fait le positionnement dynamique. Voir cette question: jQuery .css("left") renvoie "auto" au lieu de la valeur réelle dans Chrome