Jump to content
  • 0

В чём ошибка кода )


Zeferot
 Share

Question

<script type="text/javascript" src="js/jquery-1.4.2.min.js"></script>

<script > function one (objName) {

if ( $(objName).css('display') == 'none' ) {

$(objName).animate({height: 'show'}, 400);

} else {

$(objName).animate({height: 'hide'}, 200);

}

}

function two (objName) {

if ( $(objName).css('display') == 'none' ) {

$(objName).animate({height: 'show'}, 400);

} else {

$(objName).animate({height: 'hide'}, 200);

}

}

</script>

<body>

<div id="table" class="tab" >

<div class="row">

<span class="cell"><h1><img src="news/111.jpg" width="170" height="125" alt="" align="left" /> ЗАГОЛОВОК №1</h2>

<a href="#" onclick="one('#1'); return false"><img src="news/next.jpg" alt="" /></a>

<div id="1" style="display: none">

<p> РАЗВЕРНВШИЙСЯ ТЕКСТ №1 </p>

</div></span></div></div>

<div id="table" class="tab" >

<div class="row">

<span class="cell"><h1><img src="news/222.jpg" width="170" height="125" alt="" align="left" /> ЗАГОЛОВОК №2</h2>

<a href="#" onclick="one('#1'); return false"><img src="news/next.jpg" alt="" /></a>

<div id="1" style="display: none">

<p> РАЗВЕРНВШИЙСЯ ТЕКСТ №2 </p>

</div></span></div></div>

</body>

Так вот, ошибка в том, что при нажатии кнопки читать далее во втором блоке открывается текст первого блока и так независимо от колличества блоков.

Link to comment
Share on other sites

6 answers to this question

Recommended Posts

  • 0

Я дико извинияюсь, но подскажите как правильно оформить код что бы Вам было удобнее его посмотреть. Дайте ссылку на пример. Я человек в этом деле новый. =) Не судите строго.

См. рекомендации вверху этой страницы.

  • Like 1
Link to comment
Share on other sites

  • 0

 
<script type="text/javascript" src="js/jquery-1.4.2.min.js"></script>
<script >
function one (objName)
{if ( $(objName).css('display') == 'none' )
{$(objName).animate({height: 'show'}, 400); }
else {$(objName).animate({height: 'hide'}, 200);}}
function two (objName) {
if ( $(objName).css('display') == 'none' )
{$(objName).animate({height: 'show'}, 400);}
else {$(objName).animate({height: 'hide'}, 200);}}
</script>

<body id="page1">

<div id="table" class="tab" >
<div class="row">
<span class="cell"><h1><img src="news/111.jpg" width="170" height="125" alt="" align="left" /> ЗАГОЛОВОК №1</h2>
<a href="#" onclick="one('#1'); return false"><img src="news/next.jpg" alt="" /></a>

<div id="1" style="display: none">
<p> РАЗВЕРНВШИЙСЯ ТЕКСТ №1 </p>
</div>
</span>
</div>
</div>




<div id="table" class="tab" >
<div class="row">
<span class="cell"><h1><img src="news/222.jpg" width="170" height="125" alt="" align="left" /> ЗАГОЛОВОК №2</h2>
<a href="#" onclick="one('#1'); return false"><img src="news/next.jpg" alt="" /></a>

<div id="1" style="display: none">
<p> РАЗВЕРНВШИЙСЯ ТЕКСТ №2 </p>
</div>
</span>
</div>
</div>

</body>

Вот =) Буду знать на будущее.

Edited by Zeferot
Link to comment
Share on other sites

  • 0

  1. Почему не работает скрипт?
    Проблема в этих строках:
    Первый элемент:

    <a href="#" onclick="one('#1'); return false"><img src="news/next.jpg" alt="" /></a>
    <div id="1" style="display: none">
    <p> РАЗВЕРНВШИЙСЯ ТЕКСТ №1 </p>
    </div>


    Второй элемент:


    <a href="#" onclick="one('#1'); return false"><img src="news/next.jpg" alt="" /></a>
    <div id="1" style="display: none">
    <p> РАЗВЕРНВШИЙСЯ ТЕКСТ №2 </p>
    </div>


    Вы задали одинаковые идентификаторы разным элементам. id должен быть уникальным и встречаться в коде только один раз.
    Если переписать код так, чтобы у второго(третьего и т.д.) элемента был id="2"(id="3" и т.д.) скрипт будет работать.

  2. Другие ошибки в коде:
    • Идентификатор должен начинаться с латинского символа.


    • <h1><img src="news/111.jpg" width="170" height="125" alt="" align="left" /> ЗАГОЛОВОК №1</h2>


      <h1>...</h2>
      Проверяйте код на валидность.



    • <span class="cell"><h1><img src="news/111.jpg" width="170" height="125" alt="" align="left" /> ЗАГОЛОВОК №1</h2>
      <a href="#" onclick="one('#1'); return false"><img src="news/next.jpg" alt="" /></a>
      <div id="1" style="display: none">
      <p> РАЗВЕРНВШИЙСЯ ТЕКСТ №1 </p>
      </div>
      </span>


      span - строчный элемент. В нем не должны содержаться блочные элементы (h2, div).


    • Первый элемент:

      <div id="table" class="tab" >


      Второй элемент:


      <div id="table" class="tab" >


      Смотрим пункт 1.

[*]Скрипт

Для использования данного скрипта необходим порядковый идентификатор и обработчик события для каждой отдельной новости, это не совсем удобно, не так ли?

Как вариант, посмотрите данный пример:

http://jsfiddle.net/Annecy/KBdYx/

  • Like 1
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