Building 2 levels navigation from database using While()
up vote
0
down vote
favorite
I'm trying to build a navigation bar using pages stocked in a database. Nothing difficult for the first level but it gets trickier when pages have to be listed as children of a same parent. here's my code :
$dropdown = array();
while ($pages = mysqli_fetch_assoc($rq_page)) {
$url_pg = url_rewrite('page-' . $pages["id"] . '-' . $pages["intitule"] . '');
// Creating a dropdown button
if($pages["dropdown"] == "oui" && $pages["parent"] == 0) {
echo '<li class="nav-item dropdown">';
echo '<a class="nav-link dropdown-toggle" data-toggle="dropdown" id="Preview" href="#" role="button" aria-haspopup="true" aria-expanded="false">';
echo $pages["intitule"];
echo '</a>';
echo '<div class="dropdown-menu" aria-labelledby="Preview">';
foreach($dropdown as $variable) {
echo '<a class="dropdown-item" href="#">' . $variable . '</a>';
}
echo '</div>';
echo '</li>';
}
// If single page = no dropdown
else if($pages["dropdown"] == "non" && $pages["parent"] == 0) {
echo '<li class="nav-item">';
echo '<a class="nav-link" href="' . $url_pg . '">' . $pages["intitule"] . '</a>';
echo '</li>';
}
// If content is a dropdown item
else {
$dropdown = '"' . $pages["parent"] . '" => "' . $pages["intitule"] . '"';
}
}
So. First I get the databse content. Then I create an array() to list every content that has a $pages["parent"] equals the mother's ID. The while() deals with the 3 types of content : single page, dropdown page and items of the dropdown button.
i tried many PHP methods. The first level appears properly but the $dropdown array remains empty when used into the while() loop. When printed outside of the while(), it show the content I passed through the else { }
Can you see something wrong in this code and what would be the best way to create the navigation ? Let me know if I can provide more information.
Thanks for your help.
php bootstrap-4
add a comment |
up vote
0
down vote
favorite
I'm trying to build a navigation bar using pages stocked in a database. Nothing difficult for the first level but it gets trickier when pages have to be listed as children of a same parent. here's my code :
$dropdown = array();
while ($pages = mysqli_fetch_assoc($rq_page)) {
$url_pg = url_rewrite('page-' . $pages["id"] . '-' . $pages["intitule"] . '');
// Creating a dropdown button
if($pages["dropdown"] == "oui" && $pages["parent"] == 0) {
echo '<li class="nav-item dropdown">';
echo '<a class="nav-link dropdown-toggle" data-toggle="dropdown" id="Preview" href="#" role="button" aria-haspopup="true" aria-expanded="false">';
echo $pages["intitule"];
echo '</a>';
echo '<div class="dropdown-menu" aria-labelledby="Preview">';
foreach($dropdown as $variable) {
echo '<a class="dropdown-item" href="#">' . $variable . '</a>';
}
echo '</div>';
echo '</li>';
}
// If single page = no dropdown
else if($pages["dropdown"] == "non" && $pages["parent"] == 0) {
echo '<li class="nav-item">';
echo '<a class="nav-link" href="' . $url_pg . '">' . $pages["intitule"] . '</a>';
echo '</li>';
}
// If content is a dropdown item
else {
$dropdown = '"' . $pages["parent"] . '" => "' . $pages["intitule"] . '"';
}
}
So. First I get the databse content. Then I create an array() to list every content that has a $pages["parent"] equals the mother's ID. The while() deals with the 3 types of content : single page, dropdown page and items of the dropdown button.
i tried many PHP methods. The first level appears properly but the $dropdown array remains empty when used into the while() loop. When printed outside of the while(), it show the content I passed through the else { }
Can you see something wrong in this code and what would be the best way to create the navigation ? Let me know if I can provide more information.
Thanks for your help.
php bootstrap-4
How is the data organized? It looks like your approach should work as long as the "dropdown button" comes after the dropdown items.
– Joni
Nov 19 at 19:21
Here's the request : "SELECT id, intitule, parent, dropdown FROM db_page ORDER BY parent" id = INT, intitule = VARCHAR, parent = INT, dropdown = VARCHAR What do you mean a bout placing the button after the item , I used the Bootstrap 4 structure.
– Greg
Nov 19 at 19:27
add a comment |
up vote
0
down vote
favorite
up vote
0
down vote
favorite
I'm trying to build a navigation bar using pages stocked in a database. Nothing difficult for the first level but it gets trickier when pages have to be listed as children of a same parent. here's my code :
$dropdown = array();
while ($pages = mysqli_fetch_assoc($rq_page)) {
$url_pg = url_rewrite('page-' . $pages["id"] . '-' . $pages["intitule"] . '');
// Creating a dropdown button
if($pages["dropdown"] == "oui" && $pages["parent"] == 0) {
echo '<li class="nav-item dropdown">';
echo '<a class="nav-link dropdown-toggle" data-toggle="dropdown" id="Preview" href="#" role="button" aria-haspopup="true" aria-expanded="false">';
echo $pages["intitule"];
echo '</a>';
echo '<div class="dropdown-menu" aria-labelledby="Preview">';
foreach($dropdown as $variable) {
echo '<a class="dropdown-item" href="#">' . $variable . '</a>';
}
echo '</div>';
echo '</li>';
}
// If single page = no dropdown
else if($pages["dropdown"] == "non" && $pages["parent"] == 0) {
echo '<li class="nav-item">';
echo '<a class="nav-link" href="' . $url_pg . '">' . $pages["intitule"] . '</a>';
echo '</li>';
}
// If content is a dropdown item
else {
$dropdown = '"' . $pages["parent"] . '" => "' . $pages["intitule"] . '"';
}
}
So. First I get the databse content. Then I create an array() to list every content that has a $pages["parent"] equals the mother's ID. The while() deals with the 3 types of content : single page, dropdown page and items of the dropdown button.
i tried many PHP methods. The first level appears properly but the $dropdown array remains empty when used into the while() loop. When printed outside of the while(), it show the content I passed through the else { }
Can you see something wrong in this code and what would be the best way to create the navigation ? Let me know if I can provide more information.
Thanks for your help.
php bootstrap-4
I'm trying to build a navigation bar using pages stocked in a database. Nothing difficult for the first level but it gets trickier when pages have to be listed as children of a same parent. here's my code :
$dropdown = array();
while ($pages = mysqli_fetch_assoc($rq_page)) {
$url_pg = url_rewrite('page-' . $pages["id"] . '-' . $pages["intitule"] . '');
// Creating a dropdown button
if($pages["dropdown"] == "oui" && $pages["parent"] == 0) {
echo '<li class="nav-item dropdown">';
echo '<a class="nav-link dropdown-toggle" data-toggle="dropdown" id="Preview" href="#" role="button" aria-haspopup="true" aria-expanded="false">';
echo $pages["intitule"];
echo '</a>';
echo '<div class="dropdown-menu" aria-labelledby="Preview">';
foreach($dropdown as $variable) {
echo '<a class="dropdown-item" href="#">' . $variable . '</a>';
}
echo '</div>';
echo '</li>';
}
// If single page = no dropdown
else if($pages["dropdown"] == "non" && $pages["parent"] == 0) {
echo '<li class="nav-item">';
echo '<a class="nav-link" href="' . $url_pg . '">' . $pages["intitule"] . '</a>';
echo '</li>';
}
// If content is a dropdown item
else {
$dropdown = '"' . $pages["parent"] . '" => "' . $pages["intitule"] . '"';
}
}
So. First I get the databse content. Then I create an array() to list every content that has a $pages["parent"] equals the mother's ID. The while() deals with the 3 types of content : single page, dropdown page and items of the dropdown button.
i tried many PHP methods. The first level appears properly but the $dropdown array remains empty when used into the while() loop. When printed outside of the while(), it show the content I passed through the else { }
Can you see something wrong in this code and what would be the best way to create the navigation ? Let me know if I can provide more information.
Thanks for your help.
php bootstrap-4
php bootstrap-4
asked Nov 19 at 19:12
Greg
155
155
How is the data organized? It looks like your approach should work as long as the "dropdown button" comes after the dropdown items.
– Joni
Nov 19 at 19:21
Here's the request : "SELECT id, intitule, parent, dropdown FROM db_page ORDER BY parent" id = INT, intitule = VARCHAR, parent = INT, dropdown = VARCHAR What do you mean a bout placing the button after the item , I used the Bootstrap 4 structure.
– Greg
Nov 19 at 19:27
add a comment |
How is the data organized? It looks like your approach should work as long as the "dropdown button" comes after the dropdown items.
– Joni
Nov 19 at 19:21
Here's the request : "SELECT id, intitule, parent, dropdown FROM db_page ORDER BY parent" id = INT, intitule = VARCHAR, parent = INT, dropdown = VARCHAR What do you mean a bout placing the button after the item , I used the Bootstrap 4 structure.
– Greg
Nov 19 at 19:27
How is the data organized? It looks like your approach should work as long as the "dropdown button" comes after the dropdown items.
– Joni
Nov 19 at 19:21
How is the data organized? It looks like your approach should work as long as the "dropdown button" comes after the dropdown items.
– Joni
Nov 19 at 19:21
Here's the request : "SELECT id, intitule, parent, dropdown FROM db_page ORDER BY parent" id = INT, intitule = VARCHAR, parent = INT, dropdown = VARCHAR What do you mean a bout placing the button after the item , I used the Bootstrap 4 structure.
– Greg
Nov 19 at 19:27
Here's the request : "SELECT id, intitule, parent, dropdown FROM db_page ORDER BY parent" id = INT, intitule = VARCHAR, parent = INT, dropdown = VARCHAR What do you mean a bout placing the button after the item , I used the Bootstrap 4 structure.
– Greg
Nov 19 at 19:27
add a comment |
1 Answer
1
active
oldest
votes
up vote
0
down vote
accepted
Your code doesn't work because when it finds a page that has $pages["dropdown"] == "oui"
, the $dropdown
array is always empty.
The reason why it's always empty is because your query returns dropdown "item" pages last, after all of the dropdown "button" pages. If you add var_dump($dropdown)
into a few strategic places in the loop you'll see it for yourself.
A quick hacky fix is changing the ordering of your query, so that the dropdown "items" (with parent>0) are returned first:
SELECT id, intitule, parent, dropdown FROM db_page ORDER BY parent DESC
This will make every dropdown "button" include every dropdown "item," including the ones that are not related. The sort order will need further modifications to make your current approach work the way you expect.
I figured it could be a problem of request order but no matter how I turn it upside down, the result is the same : $dropdown is empty everytime is in the loop. Unfortunately I need its result in the loop.
– Greg
Nov 19 at 20:57
It seems to be working now. It wasn't just a matter of order, I also made a mistake when using the array(). It needed the keys to be declared $var[3]
– Greg
Nov 19 at 21:32
add a comment |
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
0
down vote
accepted
Your code doesn't work because when it finds a page that has $pages["dropdown"] == "oui"
, the $dropdown
array is always empty.
The reason why it's always empty is because your query returns dropdown "item" pages last, after all of the dropdown "button" pages. If you add var_dump($dropdown)
into a few strategic places in the loop you'll see it for yourself.
A quick hacky fix is changing the ordering of your query, so that the dropdown "items" (with parent>0) are returned first:
SELECT id, intitule, parent, dropdown FROM db_page ORDER BY parent DESC
This will make every dropdown "button" include every dropdown "item," including the ones that are not related. The sort order will need further modifications to make your current approach work the way you expect.
I figured it could be a problem of request order but no matter how I turn it upside down, the result is the same : $dropdown is empty everytime is in the loop. Unfortunately I need its result in the loop.
– Greg
Nov 19 at 20:57
It seems to be working now. It wasn't just a matter of order, I also made a mistake when using the array(). It needed the keys to be declared $var[3]
– Greg
Nov 19 at 21:32
add a comment |
up vote
0
down vote
accepted
Your code doesn't work because when it finds a page that has $pages["dropdown"] == "oui"
, the $dropdown
array is always empty.
The reason why it's always empty is because your query returns dropdown "item" pages last, after all of the dropdown "button" pages. If you add var_dump($dropdown)
into a few strategic places in the loop you'll see it for yourself.
A quick hacky fix is changing the ordering of your query, so that the dropdown "items" (with parent>0) are returned first:
SELECT id, intitule, parent, dropdown FROM db_page ORDER BY parent DESC
This will make every dropdown "button" include every dropdown "item," including the ones that are not related. The sort order will need further modifications to make your current approach work the way you expect.
I figured it could be a problem of request order but no matter how I turn it upside down, the result is the same : $dropdown is empty everytime is in the loop. Unfortunately I need its result in the loop.
– Greg
Nov 19 at 20:57
It seems to be working now. It wasn't just a matter of order, I also made a mistake when using the array(). It needed the keys to be declared $var[3]
– Greg
Nov 19 at 21:32
add a comment |
up vote
0
down vote
accepted
up vote
0
down vote
accepted
Your code doesn't work because when it finds a page that has $pages["dropdown"] == "oui"
, the $dropdown
array is always empty.
The reason why it's always empty is because your query returns dropdown "item" pages last, after all of the dropdown "button" pages. If you add var_dump($dropdown)
into a few strategic places in the loop you'll see it for yourself.
A quick hacky fix is changing the ordering of your query, so that the dropdown "items" (with parent>0) are returned first:
SELECT id, intitule, parent, dropdown FROM db_page ORDER BY parent DESC
This will make every dropdown "button" include every dropdown "item," including the ones that are not related. The sort order will need further modifications to make your current approach work the way you expect.
Your code doesn't work because when it finds a page that has $pages["dropdown"] == "oui"
, the $dropdown
array is always empty.
The reason why it's always empty is because your query returns dropdown "item" pages last, after all of the dropdown "button" pages. If you add var_dump($dropdown)
into a few strategic places in the loop you'll see it for yourself.
A quick hacky fix is changing the ordering of your query, so that the dropdown "items" (with parent>0) are returned first:
SELECT id, intitule, parent, dropdown FROM db_page ORDER BY parent DESC
This will make every dropdown "button" include every dropdown "item," including the ones that are not related. The sort order will need further modifications to make your current approach work the way you expect.
answered Nov 19 at 20:08
Joni
75.6k996148
75.6k996148
I figured it could be a problem of request order but no matter how I turn it upside down, the result is the same : $dropdown is empty everytime is in the loop. Unfortunately I need its result in the loop.
– Greg
Nov 19 at 20:57
It seems to be working now. It wasn't just a matter of order, I also made a mistake when using the array(). It needed the keys to be declared $var[3]
– Greg
Nov 19 at 21:32
add a comment |
I figured it could be a problem of request order but no matter how I turn it upside down, the result is the same : $dropdown is empty everytime is in the loop. Unfortunately I need its result in the loop.
– Greg
Nov 19 at 20:57
It seems to be working now. It wasn't just a matter of order, I also made a mistake when using the array(). It needed the keys to be declared $var[3]
– Greg
Nov 19 at 21:32
I figured it could be a problem of request order but no matter how I turn it upside down, the result is the same : $dropdown is empty everytime is in the loop. Unfortunately I need its result in the loop.
– Greg
Nov 19 at 20:57
I figured it could be a problem of request order but no matter how I turn it upside down, the result is the same : $dropdown is empty everytime is in the loop. Unfortunately I need its result in the loop.
– Greg
Nov 19 at 20:57
It seems to be working now. It wasn't just a matter of order, I also made a mistake when using the array(). It needed the keys to be declared $var[3]
– Greg
Nov 19 at 21:32
It seems to be working now. It wasn't just a matter of order, I also made a mistake when using the array(). It needed the keys to be declared $var[3]
– Greg
Nov 19 at 21:32
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53381156%2fbuilding-2-levels-navigation-from-database-using-while%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
How is the data organized? It looks like your approach should work as long as the "dropdown button" comes after the dropdown items.
– Joni
Nov 19 at 19:21
Here's the request : "SELECT id, intitule, parent, dropdown FROM db_page ORDER BY parent" id = INT, intitule = VARCHAR, parent = INT, dropdown = VARCHAR What do you mean a bout placing the button after the item , I used the Bootstrap 4 structure.
– Greg
Nov 19 at 19:27