Как заставить плагин Superfish jQuery динамически работать с несколькими циклами в PHP - PullRequest
0 голосов
/ 14 сентября 2010

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

Я начал использовать плагин Superfish JQuery для навигации и получил код, работающий отлично и легко со статическими ссылками., но когда я пытаюсь изменить это на динамические ссылки, у меня возникают проблемы с тем, чтобы тег 2-го уровня работал правильно;показывать только при обнаружении ссылок 2-го уровня, а затем показывать только один раз, прежде чем ссылки 2-го уровня будут выписаны из базы данных.

Надеюсь, я прояснил проблему.Извинения, если я не.

<ul class="sf-menu">
        <?php
            // A varible that increments on every loop of the below "while" statement
            $count == 0;

            $result = mysql_query("SELECT * FROM web_navbar_links WHERE link_parent='1' AND visible='1' ORDER BY position ASC");
            while ($row = mysql_fetch_object($result)) {
                $parentID    = $row->id;
                $parentLevel = $row->slug;
                // Increment the counter varible by one
                $count++;

                echo "<li";
                    switch ($parentLevel) {
                        case "business":
                            echo " id='business'";
                            break;

                        case "education":
                            echo " id='education'";
                            break;

                        case "consumer":
                            echo " id='consumer'";
                            break;
                    }
                    echo "><a>".ucwords(trim($row->link_name))."</a>";

                    $result2 = mysql_query("SELECT * FROM web_navbar_links WHERE link_child='1' AND parent_relationID='".$parentID."' AND visible='1' ORDER BY position ASC");
                    if ($row2 = mysql_fetch_object($result2)) {
                        echo "<ul>"; //PROBLEM LIES HERE!! ATM THE <UL> WRITES ONCE BUT THE LOOP ONLY READS BACK THE LAST ENTRY FROMT HE db.
                        while ($row2 = mysql_fetch_object($result2)) {
                            echo "<li><a href='http://". ROOT . ADMIN . SECTIONS . TEMPLATES . $row2->link_href."?".$row2->slug."=".$row2->slug."' title='".$row2->link_title."'>".$row2->link_name."</a>";
                                echo "<ul>";
                                    echo "<li><a href='#'>blah</a></li>";
                                echo "</ul>";
                            echo "</li>";
                        }
                        echo "</ul>";
                    }
                echo "</li>";

                if ($count < 3) {
                    echo "<li class='breaker'></li>";
                }
                else {
                    echo "";
                }
            }
        ?>
    </ul>

1 Ответ

0 голосов
/ 14 сентября 2010

Я думаю, что проблема заключается в этой строке:

if ($row2 = mysql_fetch_object($result2)) {

Это переместит счетчик записи вперед, поэтому при следующем вызове:

while ($row2 = mysql_fetch_object($result2)) {

$row2 будет заполнено вторым рядом. Поскольку вы не используете первый ряд между двумя выделенными строками, вы потеряете его.

Я предлагаю вызвать mysql_num_rows($result2), чтобы получить количество возвращаемых строк вместо первого mysql_fetch_object($result2) в операторе if.

                $result2 = mysql_query("SELECT * FROM web_navbar_links WHERE link_child='1' AND parent_relationID='".$parentID."' AND visible='1' ORDER BY position ASC");
                if (mysql_num_rows($result2) > 0) {
                    echo "<ul>"; //PROBLEM LIES HERE!! ATM THE <UL> WRITES ONCE BUT THE LOOP ONLY READS BACK THE LAST ENTRY FROMT HE db.
                    while ($row2 = mysql_fetch_object($result2)) {
                        echo "<li><a href='http://". ROOT . ADMIN . SECTIONS . TEMPLATES . $row2->link_href."?".$row2->slug."=".$row2->slug."' title='".$row2->link_title."'>".$row2->link_name."</a>";
                            echo "<ul>";
                                echo "<li><a href='#'>blah</a></li>";
                            echo "</ul>";
                        echo "</li>";
                    }
                    echo "</ul>";
                }
...