Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

HTML+CSS+JavaScript

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: JS и стиль
 
 автор: freeing   (17.06.2008 в 13:18)   письмо автору
 
 

помогите решить следующий вопрос, я стиль страниц задаю не при помощи CSS а из JS файла

пример:


...
     document.getElementById("div_0000").style.zIndex          = 0;
     document.getElementById("div_0010").style.zIndex          = 1;
     document.getElementById("div_0120").style.zIndex          = 2;
     document.getElementById("div_0130").style.zIndex          = 3;
     document.getElementById("div_0140").style.zIndex          = 4;

     document.getElementById("div_0000").style.position        = "absolute";
     document.getElementById("div_0010").style.position        = "absolute";
     document.getElementById("div_0120").style.position        = "absolute";
     document.getElementById("div_0130").style.position        = "absolute";
     document.getElementById("div_0140").style.position        = "absolute";
...


так вот, проблема в том что если страница содержит какой либо текст, происходит не очень корректная загрузка, вначале грузится текст а потом JS стиль страниц

как можно решить данный трабл?

   
 
 автор: freeing   (17.06.2008 в 13:20)   письмо автору
 
   для: freeing   (17.06.2008 в 13:18)
 

просьба


.style.visibility = "hidden";


не предлогать

   
 
 автор: AlexSol   (17.06.2008 в 14:18)   письмо автору
 
   для: freeing   (17.06.2008 в 13:20)
 

после такого дополнения никак

   
 
 автор: freeing   (17.06.2008 в 14:44)   письмо автору
 
   для: AlexSol   (17.06.2008 в 14:18)
 

все браузеры JS грузят не в начале а в конце?

и как определить 100% конец загрузки страницы?

   
 
 автор: AlexSol   (17.06.2008 в 15:03)   письмо автору
 
   для: freeing   (17.06.2008 в 14:44)
 

document.onLoad событие грузит в начале, просто обратиться к элементу по id можно только после его загрузки

   
 
 автор: freeing   (18.06.2008 в 10:18)   письмо автору
 
   для: AlexSol   (17.06.2008 в 15:03)
 

можно простенький пример?

я не совсем понял!

   
 
 автор: PAT   (18.06.2008 в 11:35)   письмо автору
 
   для: freeing   (18.06.2008 в 10:18)
 

Пример 1:
<html>
<head>
<script>
document.getElementById ("div_0000").style.zIndex = 0; 
</script>
</head>
<body>
...
<div id="div_0000">text</div>
...
</body>
</html>
Браузер выдаст ошибку - объект с id="div_0000" на момент обращения к нему ещё не сформирован.

Пример 2:
<html>
<head>
<script>
onload = function () {document.getElementById ("div_0000").style.zIndex = 0}
</script>
</head>
<body>
...
<div id="div_0000">text</div>
...
</body>
</html>
Здесь всё в порядке - сначала окно полностью загрузится, сформируются ВСЕ HTML-объекты, в т.ч. и объект с id="div_0000", к которому можно будет обратиться.

Пример 3:
<html>
<body>
...
<div id="div_0000">text</div>
<script>
document.getElementById ("div_0000").style.zIndex = 0;
</script>
...
</body>
</html>
Здесь тоже всё будет работать - обращение к объекту с id="div_0000" произойдет сразу после того, как объект будет сформирован.

В общем, сначала должен сформироваться объект (вместе с его текстом, раз он написан прямо в HTML-коде) и только потом можно будет через JS обращаться к каким-то его свойствам.

   
 
 автор: freeing   (18.06.2008 в 11:46)   письмо автору
 
   для: PAT   (18.06.2008 в 11:35)
 

я обратил внимание на то что

<style>
#div_0130
{
display: none;
}
</style>

срабатывает раньше onload

   
 
 автор: PAT   (18.06.2008 в 11:55)   письмо автору
 
   для: freeing   (18.06.2008 в 11:46)
 

Так это CSS, а не Javascript.

Правила CSS, определенные в заголовке документа, действительно применяются к телу документа еще ДО НАЧАЛА ЗАГРУЗКИ.
А вот Javascript - как показано выше - только к сформированным объектам.

Чего вам надо-то, болезному? :-))
Вы же начали с того, что CSS не пользуете, а пользуете ТОЛЬКО JScript.

   
 
 автор: freeing   (18.06.2008 в 13:10)   письмо автору
 
   для: PAT   (18.06.2008 в 11:55)
 

Как отменить CSS?

Я в шапке кинул

<style>
#div_0130
{
    display: none;
}
</style>


А теперь мне его надо отменить из JS


типо так:



<html>
<head>

<style>
#div_0000
{
    display: none;
}
</style>

<script>
function Load()
{
    document.getElementById("div_0000").style.display = '';

</script>

</head>
<body onload = 'Load();'>
<div id="div_0000">text</div>
</body>
</html>

   
 
 автор: AlexSol   (18.06.2008 в 13:15)   письмо автору
 
   для: freeing   (18.06.2008 в 13:10)
 

document.getElementById ("div_0000").style.display='';

   
 
 автор: freeing   (18.06.2008 в 13:17)   письмо автору
 
   для: AlexSol   (18.06.2008 в 13:15)
 

не работает!



<html> 
<head> 

<style> 
#div_0000 

    display: none; 

</style> 

<script> 
function Load() 

    document.getElementById("div_0000").style.display = ''; 
}  
</script> 

</head> 
<body onload = 'Load();'> 
<div id="div_0000">text</div> 
</body> 
</html> 

   
 
 автор: PAT   (18.06.2008 в 14:04)   письмо автору
 
   для: freeing   (18.06.2008 в 13:17)
 

document.getElementById ("div_0000").style.display = 'block';

   
 
 автор: freeing   (18.06.2008 в 17:15)   письмо автору
 
   для: PAT   (18.06.2008 в 14:04)
 

спасибо

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования