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

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

09.05.2012, 23:34. Показов 1808. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru