Вопрос

Я пытаюсь запустить центрированное окно браузера с помощью кнопки-формы, используя следующий код...

http://www.bbc.co.uk ','testwin','ширина=400, высота=400, слева=(screen.availWidth-400)/2, сверху=(screen.availHeight-400)/2');вернуть значение false"> Кнопка проверки

В новом браузере отображаются правильные высота и ширина, но атрибуты left и top игнорируются, поэтому окно отображается в верхнем левом углу.

Не слишком ли я амбициозен, пытаясь сделать этот код встроенным?Есть ли какой-либо другой синтаксис, который я должен использовать, или я должен отказаться и вызвать функцию вместо этого (я бы предпочел этого не делать, если смогу избежать этого)?

Я использую Firefox 3.0.17 (последнюю версию), но тот же эффект происходит и в IE7.

TIA, Алан Харрис-Рид

Это было полезно?

Решение

http://www.tek-tips.com/faqs.cfm?fid=2296 объясняет, как это сделать.Но я бы рекомендовал использовать вместо этого плавающий Div из-за блокировки всплывающих окон.

Допустим, вы хотите открыть окно размером 200h x 150w.Взяв половину высоты и ширины (100 и 75 соответственно), вы можете точно определить центр окна.Затем с помощью небольшой математики вы можете расположить окно по центру.Вот как это делается

<SCRIPT LANGUAGE="JavaScript">
function MyPopUpWin() {
var iMyWidth;
var iMyHeight;
//half the screen width minus half the new window width (plus 5 pixel borders).
iMyWidth = (window.screen.width/2) - (75 + 10);
//half the screen height minus half the new window height (plus title and status bars).
iMyHeight = (window.screen.height/2) - (100 + 50);
//Open the window.
var win2 = window.open("filename.htm","Window2","status=no,height=200,width=150,resizable=yes,left=" + iMyWidth + ",top=" + iMyHeight + ",screenX=" + iMyWidth + ",screenY=" + iMyHeight + ",toolbar=no,menubar=no,scrollbars=no,location=no,directories=no");
win2.focus();
}
</SCRIPT>

Чтобы вызвать эту функцию в HTML, используйте это:

<A HREF="javascript:MyPopUpWin()">This is the link</a>
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top