Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/9: Рейтинг темы: голосов - 9, средняя оценка - 4.78
 Аватар для Рingvin
3 / 3 / 1
Регистрация: 08.05.2011
Сообщений: 31

Вертикальное и горизонтальное центрирование

09.05.2012, 23:34. Показов 1826. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер!
Решил расположить слой по середине экрана. Для начала по горизонтали. Можно действовать так: (ширина_окна / 2) - (ширина_слоя / 2). Аналогично с центрированием по вертикали. Вот что я сотворил:
JavaScript
1
2
3
4
<script language="JavaScript">
document.all[6].style.left = (screen.width/2)-(document.all[6].style.width/2)+"px";
document.all[6].style.top = (screen.height/2)-(document.all[6].style.height/2)+"px";
</script>
6 это в массиве all и есть сам слой.

PS Я совсем новичок, и если написал какие-нибудь противоречивые и жуть как несвязные вещи, прошу пояснить мне, чтобы в интернете стало на один меньше "умных" программистов

Добавлено через 35 минут
И самое главное, что хотел сказать - не работает Почему?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.05.2012, 23:34
Ответы с готовыми решениями:

Вертикальное центрирование
Есть header и footer. Между ними должна быть кнопка, которая на разных мониторах будет находится по-центру по вертикали блока content : ...

Вертикальное и горизонтальное меню не сворачивается
Имеется горизонтальное меню, в котором вложено ещё 2 подменю. 1-е подменю открывается вертикально, 2-е гор-но, сбоку верт-го. Проблема...

Вертикальное центрирование select
Здравствуйте! Не могу вертикально поставить select в центре блока &lt;div class=&quot;select&quot;&gt; &lt;span...

7
 Аватар для Heleg
209 / 209 / 6
Регистрация: 23.10.2011
Сообщений: 971
10.05.2012, 06:40
вот тут я для себя выяснил, что к стилю элеметна нельзя обратиться через style. то есть document.all[6].style.width/2 - некорректно

Не по теме:

p.s. для выравнивания есть же css

1
супермизантроп
Эксперт JS
3941 / 2979 / 692
Регистрация: 18.04.2012
Сообщений: 8,629
10.05.2012, 10:22
JavaScript
1
2
document.all[6].style.left = (screen.width/2)-(document.all[6].style.width/2)+"px";
document.all[6].style.top = (screen.height/2)-(document.all[6].style.height/2)+"px";
Пара замечаний.

1. Коллекция document.all - она всем замечательна, кроме одного: корректно она работает только в браузере MSIE.
Для идентификации любого элемента (тега) страницы лучше использовать кроссбраузерные (работающие во всех браузерах) методы. Например, самым распространённым кроссбраузерным методом является метод document.getElementById ('myID'), где myID - это значение уникального в пределах страницы идентификатора, который вам надо прописать в id в интересующем вас 6-м по очереди теге на вашей странице.

2. Рад, что вы запомнили моё сообщение о том, что текущие параметры стиля через объект style узнать нельзя.
Но в данном случае есть простейший выход из этой ситуации.
Дело в том, что у любого тега можно узнать его габариты (высоту/ширину), не прибегая к свойствам стиля.
Во всех браузерах поддерживаются свойства тега offsetWidth (вернёт ширину тега в пикселях) и offsetHeight (высота в пикселях).

Так что ваш код в работоспособном виде (и для всех браузеров) следует записать так:
JavaScript
1
2
document.getElementById ('myID').style.left = (screen.width / 2) - (document.getElementById ('myID').offsetWidth / 2) + "px";
document.getElementById ('myID').style.top = (screen.height / 2) - (document.getElementById ('myID').offsetHeight / 2) + "px";
1
 Аватар для Рingvin
3 / 3 / 1
Регистрация: 08.05.2011
Сообщений: 31
10.05.2012, 10:27  [ТС]
Большое спасибо всем! kalabuni, отдельное спасибо! Теперь прояснил себе некоторые знания в JavaScript
0
супермизантроп
Эксперт JS
3941 / 2979 / 692
Регистрация: 18.04.2012
Сообщений: 8,629
10.05.2012, 10:37
Heleg, ещё одно замечание.
Только сейчас заметил.

Я не знаю - зачем вы делите ширину и высоту тега напополам.
Но, если бы передо мной стояла задача поместить тег точно посерёдке экрана, я бы делить не стал.

0
 Аватар для Heleg
209 / 209 / 6
Регистрация: 23.10.2011
Сообщений: 971
10.05.2012, 11:03

Не по теме:

ээээ, я думаю это адресовалось не мне :)


kalabuni, тут то как раз всё правильно
Миниатюры
Вертикальное и горизонтальное центрирование  
0
супермизантроп
Эксперт JS
3941 / 2979 / 692
Регистрация: 18.04.2012
Сообщений: 8,629
10.05.2012, 11:43
Точно

Просто я обычно делю один раз, а у вас - бросилось в глаза - два деления.
Вот и отписался.
Извиняюсь.
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<!doctype>
<html>
<head>
<style>
html, body {height: 100%; margin: 0; background-color: white}
#myID      {width: 56.78%; height: 67.89%; background-color: black; position: absolute}
</style>
<script>
onload = function ()
{
with (document)
   {
   var obj = getElementById ('myID');
   obj.style.left = (body.clientWidth  - obj.offsetWidth)  / 2 + 'px';
   obj.style.top  = (body.clientHeight - obj.offsetHeight) / 2 + 'px';
   }
}
</script>
</head>
<body>
<div id="myID"></div>
</body>
</html>
0
 Аватар для Рingvin
3 / 3 / 1
Регистрация: 08.05.2011
Сообщений: 31
12.05.2012, 09:28  [ТС]
Кстати, сначала не было по середине. Я заменил
JavaScript
1
2
document.getElementById ('come').style.left = (screen.width / 2) - ((document.getElementById ('come').offsetWidth) / 2) + "px";
document.getElementById ('come').style.top = (screen.height / 2) - ((document.getElementById ('come').offsetHeight) / 2)+ "px";
На:
JavaScript
1
2
document.getElementById ('come').style.left = (document.body.clientWidth / 2) - ((document.getElementById ('come').offsetWidth) / 2) + "px";
document.getElementById ('come').style.top = (document.body.clientHeight / 2) - ((document.getElementById ('come').offsetHeight) / 2)+ "px";
И всё встало ровно на середину
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.05.2012, 09:28
Помогаю со студенческими работами здесь

Горизонтальное центрирование DIV
Добрый день! В блоке есть несколько DIV с float: left. Подскажите, пожалуйста, как их по горизонтали отцентровать? &lt;!DOCTYPE...

Горизонтальное центрирование блока
День добрый.Возникла такая проблема,не получается отцентрировать блок,уже тупо все переискал но решения не нашел. Вот собственно код: ...

Bootstrap 4 Вертикальное центрирование элемента
Великие, помогите центрировать данную конструкцию по вертикали. Класс align-items-center почему-то не робзит. Возможно я что-то не так...

Вертикальное центрирование ссылки в резиновом блоке
Доброго всем дня! Делаю резиновый шаблон для сайта, в нем есть вертикальное меню из 3х блоков, каждый высотой по 33,33% от родителя. В...

Горизонтальное/Вертикальное расположение
Всем привет Подскажите, где толково объяснено как настраивать проект под горизонтальное расположение. Очень сложно сходу сообразить с...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru