Jump to content
  • 0

ИЕ не хочет позиционировать блок по высоте


bmv
 Share

Question

http://www.yarta.com/, нажмите на Австрию.

ИЕ не хочет позиционировать вызываемый блок по высоте. Берет вместо высоты сайта высоту экрана и позиционирует блок относительно первого экрана, когда пользуешься прокруткой блок остается висеть вверху. А вот в ФФ делает все правильно. Помогите забороть ослика.

Чтобы вам не рыться в коде:

HTML:

<a href="#?w=500" rel="popup1" class="poplight"><img src="images/photos/01-austria.png" alt="Герб Австрии">
<span>Австрия</span></a>

JS:

<script>
$(document).ready(function(){

//When you click on a link with class of poplight and the href starts with a #
$('a.poplight[href^=#]').click(function() {
var popID = $(this).attr('rel'); //Get Popup Name
var popURL = $(this).attr('href'); //Get Popup href to define size

//Pull Query & Variables from href URL
var query= popURL.split('?');
var dim= query[1].split('&');
var popWidth = dim[0].split('=')[1]; //Gets the first query string value

//Fade in the Popup and add close button
$('#' + popID).fadeIn().css({ 'width': Number( popWidth ) }).prepend('<a href="#" class="close"><img src="/images/close.png" class="btn_close" title="Закрыть окно" alt="Закрыть окно" /></a>');

//Define margin for center alignment (vertical + horizontal) - we add 80 to the height/width to accomodate for the padding + border width defined in the css
var popMargTop = ($('#' + popID).height() + 80) / 2;
var popMargLeft = ($('#' + popID).width() + 80) / 2;

//Apply Margin to Popup
$('#' + popID).css({
'margin-top' : -popMargTop,
'margin-left' : -popMargLeft
});

//Fade in Background
$('body').append('<div id="fade"></div>'); //Add the fade layer to bottom of the body tag.
$('#fade').css({'filter' : 'alpha(opacity=50)'}).fadeIn(); //Fade in the fade layer

return false;
});


//Close Popups and Fade Layer
$('a.close, #fade').live('click', function() { //When clicking on the close or fade layer...
$('#fade , .popup_block').fadeOut(function() {
$('#fade, a.close').remove();
}); //fade them both out
return false;
});
});
</script>

CSS:

/* Popup window */
#fade {
display: none;
background: #fff;
position: fixed;
left: 0;
top: 0;
width: 100%;
height: 100%;
opacity: .50;
z-index: 9999;
}

.popup_block{
display: none;
float: left;
font-size: 12px;
font-weight: bold;
position: fixed;
top: 50%;
left: 50%;
z-index: 99999;
height: 125px;
color: #FFF;
border: 1px solid #FFF;
}

.popup_block p {
font-size: 12px;
}

img.btn_close {
float: right;
margin: -1px -1px 0 0;
}

.zagolovok_popup {
height:20px;
background: #94be4a;
border-bottom: 1px solid #FFF;
padding: 5px 0 0 10px;
}

/*--Making IE6 Understand Fixed Positioning--*/
*html #fade {
position: absolute;
}

*html .popup_block {
position: absolute;
}

Link to comment
Share on other sites

1 answer to this question

Recommended Posts

  • 0

Ну так все правильно, ие6 не понимает фиксед, вот ты ему и влепил абсолют. Но абсолют считается от верха странички. Тоесть для ие6 тебе еще придеться добавлять

$(window).scrollTop()

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

 Share

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue. See more about our Guidelines and Privacy Policy