php2014 Posted June 2, 2014 Share Posted June 2, 2014 Hi all, I'm trying to code a dependable dropdownlist with php/mysql/ajax. Goal is to select one thing in the first dropdown and depending on that option (and without reloading the page) enabling the second and add the options to the second, dependant on the first. This is the index : <?php require_once($_SERVER['DOCUMENT_ROOT'].'/dbconnect.php'); ?> <script type="text/javascript" src="http://ajax.googleapis.com/ ajax/libs/jquery/1.4.2/jquery.min.js"></script> <script type="text/javascript"> $(document).ready(function() { $(".country").change(function() { var id=$(this).val(); var dataString = 'id='+id; $.ajax ({ type: "POST", url: "edit_form.php", data: dataString, cache: false, success: function(html) { $(".city").html(html); } }); }); }); </script> <?php $id_test=$_POST['selector']; $N = count($id_test); for($i=0; $i < $N; $i++) { $result = mysqli_query($conn, "SELECT * FROM cloud where id='$id_test[$i]'"); while($row = mysqli_fetch_array($result)) { $id_bird = $row['id']; ?> <div style="margin:80px"> <label>Country :</label> <select name="country" class="country"> <option selected="selected">--Select Country--</option> <?php $sql=mysqli_query($conn, "SELECT category.id AS cat_id, category.name, category.type, cloud.id FROM cloud,category,link_category_cloud WHERE link_category_cloud.cloud_id = cloud.id AND link_category_cloud.category_id = category.id AND cloud.id='$id_test[$i]'"); while($row=mysqli_fetch_array($sql)) { $id_test=$row['cat_id']; $data=$row['name']; echo '<option value="'.$id_test.'">'.$data.'</option>'; } ?> </select> <br/> <br/> <label>City :</label> <select name="city" class="city"> <option selected="selected">--Select City--</option> </select> </div> <?php } } ?> And this is the edit_form.php part : <?php require_once($_SERVER['DOCUMENT_ROOT'].'/dbconnect.php'); $cat_id = $_GET['cat_id']; $cloud_id = $_GET['id']; if($_POST['id_test']) { $id_test=$_POST['id_test']; $data=$_POST['data']; $sql=mysqli_query($conn, "SELECT * FROM link_category_cloud WHERE category_id={$cat_id}"); $data=$row['cloud_id']; $id_test=$_POST['id_test']; echo '<option value="'.$id_test.'">'.$id_test.' '.$data.'</option>'; //} } ?> Now, it does not work. I'm not only tring to pass through ID to 'edit_form.php', but also $data and $id_test. Any idea how I can do this? Thank you very much, all help is so appreciated!! Quote Link to comment https://forums.phpfreaks.com/topic/288939-dependable-dropdownlist-phpmysqlajax/ Share on other sites More sharing options...
fastsol Posted June 2, 2014 Share Posted June 2, 2014 Here is a tutorial I have on this subject. http://amecms.com/article/Building-Chained-Select-Boxes-with-Jquery-and-PHP Quote Link to comment https://forums.phpfreaks.com/topic/288939-dependable-dropdownlist-phpmysqlajax/#findComment-1481683 Share on other sites More sharing options...
php2014 Posted June 2, 2014 Author Share Posted June 2, 2014 (edited) Here is a tutorial I have on this subject. http://amecms.com/article/Building-Chained-Select-Boxes-with-Jquery-and-PHP Hi, thanks. Looks good. But, how can I translate it to my own code? I need to have mysql in it, the first dropdown filled from mysql and the second also filled from mysql but then based on the first dropdown. Maybe you can give me some pointers :-). The problem is I have seen quite some topics about it but for myself I don't get it to work. Edited June 2, 2014 by php2014 Quote Link to comment https://forums.phpfreaks.com/topic/288939-dependable-dropdownlist-phpmysqlajax/#findComment-1481688 Share on other sites More sharing options...
fastsol Posted June 2, 2014 Share Posted June 2, 2014 I explain how to use a database in the article. You simply need to get an array of list items from the database using normal queries and then put that array into the foreach loops in the example. It's the same exact theory, but you're making an array of list items from the db rather than hard coding the list like my example. Here's a quick example from a db query using the $makes from the tutorial. $get = mysqli_query($conn, "SELECT * FROM `car_makes`"); while($row = mysqli_fetch_assoc($get)) { $makes[] = $row['make']; } // Now $makes is an array from the DB listing. Quote Link to comment https://forums.phpfreaks.com/topic/288939-dependable-dropdownlist-phpmysqlajax/#findComment-1481691 Share on other sites More sharing options...
Barand Posted June 2, 2014 Share Posted June 2, 2014 This works (using arrays instead of db but principle is the same) example2.php example1.php Quote Link to comment https://forums.phpfreaks.com/topic/288939-dependable-dropdownlist-phpmysqlajax/#findComment-1481696 Share on other sites More sharing options...
php2014 Posted June 3, 2014 Author Share Posted June 3, 2014 Ok. Well as you can see I use an array too with the selector part at the beginning. However, I dont get it to work in my code from the first post tk passthrough more then 1 variable from mysql. I also don't see this from the tutorial. What am I doing wrong ? Problem is I saw a lot of examples but I just dont get it to work for my own purposes. Thanks! Quote Link to comment https://forums.phpfreaks.com/topic/288939-dependable-dropdownlist-phpmysqlajax/#findComment-1481736 Share on other sites More sharing options...
Barand Posted June 3, 2014 Share Posted June 3, 2014 (edited) Try some debugging and adding an alert $(document).ready(function() { $(".country").change(function() { var id=$(this).val(); var dataString = 'id='+id; alert(datastring); //<-- what does this show $.ajax ({ type: "POST", url: "edit_form.php", data: dataString, cache: false, success: function(html) { $(".city").html(html); } }); }); }); and try it with datastring = '{"id":$(this).val()}'; Edited June 3, 2014 by Barand Quote Link to comment https://forums.phpfreaks.com/topic/288939-dependable-dropdownlist-phpmysqlajax/#findComment-1481739 Share on other sites More sharing options...
php2014 Posted June 3, 2014 Author Share Posted June 3, 2014 (edited) Try some debugging and adding an alert $(document).ready(function() { $(".country").change(function() { var id=$(this).val(); var dataString = 'id='+id; alert(datastring); //<-- what does this show $.ajax ({ type: "POST", url: "edit_form.php", data: dataString, cache: false, success: function(html) { $(".city").html(html); } }); }); }); and try it with datastring = '{"id":$(this).val()}'; Hi Barand, I used your code as follows : $(document).ready(function() { $(".country").change(function() { var id=$(this).val(); var datastring = '{"id":$(this).val()}'; alert(datastring); //<-- what does this show $.ajax ({ type: "POST", url: "edit_form.php", data: dataString, cache: false, success: function(html) { $(".city").html(html); } }); }); }); However I receive the following message : {"id":$(this).val()} Am I doing something wrong here? Edited June 3, 2014 by php2014 Quote Link to comment https://forums.phpfreaks.com/topic/288939-dependable-dropdownlist-phpmysqlajax/#findComment-1481780 Share on other sites More sharing options...
php2014 Posted June 3, 2014 Author Share Posted June 3, 2014 I explain how to use a database in the article. You simply need to get an array of list items from the database using normal queries and then put that array into the foreach loops in the example. It's the same exact theory, but you're making an array of list items from the db rather than hard coding the list like my example. Here's a quick example from a db query using the $makes from the tutorial. $get = mysqli_query($conn, "SELECT * FROM `car_makes`"); while($row = mysqli_fetch_assoc($get)) { $makes[] = $row['make']; } // Now $makes is an array from the DB listing. I'm really , really trying hard to make it work with your example but it just does not work. This is the first part: <script> $('#makes').change(function(){ //Basically saying when the first select box changes values run the function below. var make = $(this).val(); // Grab the value of the selection to send to the select-request.php via ajax $.post('select-request.php', {make:make}, function(data){ // Run a ajax request and send the var make as a post variable named "make" and return the info in the "data" var. $('#models').html(data); // Have jquery change the html within the second select box with the "data" we got back from the ajax request. }); }); </script> <?php $cloud_id=$_POST['selector']; $N = count($cloud_id); for($i=0; $i < $N; $i++) { $result = mysqli_query($conn, "SELECT * FROM cloud where id='$cloud_id[$i]'"); while($row = mysqli_fetch_array($result)) { ?> <?php // An array of options for the first select box. $makes=mysqli_query($conn, "SELECT category.id AS cat_id, category.name, category.type, cloud.id FROM cloud,category,link_category_cloud WHERE link_category_cloud.cloud_id = cloud.id AND link_category_cloud.category_id = category.id AND cloud.id='$cloud_id[$i]'"); while($row=mysqli_fetch_array($makes)) { // Displays the posted info if(isset($_POST['submit'])) { echo '<pre>'; print_r($_POST); echo '</pre>'; } ?> <form action="" method="post"> <select id="makes" name="makes"><!-- Make sure to give the select box a id, this will make it much easier to target with jquery. --> // Build the options for the first select box <option selected="selected">--Select Country--</option> <?php foreach($makes as $m){ echo '<option value="'.$m.'">'.$m.'</option>'; } } ?> </select> <select id="models" name="models"><!-- Make sure to give the select box a id, this will make it much easier to target with jquery. --> </select> <input type="submit" name="submit" value="Submit"> </form> <?php } } ?> And this is select-request.php : <?php error_reporting(E_ALL); //Remove this line for production, it simply will allow php to display any errors // I built arrays based on the value names in the $makes array $get = mysqli_query($conn, "SELECT * FROM link_category_cloud WHERE category_id={$makes}"); while($row = mysqli_fetch_assoc($get)) { $makes[] = $row['make']; } // Now $makes is an array from the DB listing. //We check to see if the "make" post has come through before we do any processing. if(isset($_POST['make'])) { // In my example I assign the posted make to a variable and use strtolower() to put all the text in lowercase so it will match an array above. $model = strtolower($_POST['make']); // Using a varable variable I put it into a foreach loop and just like the first select box build the options. // Using echo we are able to essentially send back the data. // Basically whatever you echo on this page will be output on the main page. foreach($$model as $mo){ echo '<option value="'.$mo.'">'.$mo.'</option>'; } } ?> All I want is that I can select this first dropdown and fetch the data from that dropdownlist from mysql and then pass it through to the second list. Data that needs to be passed through to the second dropdown is the cloud_id and category_id. I am really at a dead end here. I don't want to ask to much but maybe you can try to make what I want or something alike and explain what is happening? What I have now is various examples, what I appreciate BIG time, but both don't work and I do not know why or how I could combine it. Thank you very much. Quote Link to comment https://forums.phpfreaks.com/topic/288939-dependable-dropdownlist-phpmysqlajax/#findComment-1481788 Share on other sites More sharing options...
Barand Posted June 3, 2014 Share Posted June 3, 2014 try $(document).ready(function() { $(".country").change(function() { $.post ( "edit_form.php", {"id": $(this).val()}, function(data) { $(".city").html(data); }, "text" ); }); }); Quote Link to comment https://forums.phpfreaks.com/topic/288939-dependable-dropdownlist-phpmysqlajax/#findComment-1481796 Share on other sites More sharing options...
fastsol Posted June 3, 2014 Share Posted June 3, 2014 You have all sorts of weird things going on in that last post of code. If you can zip me up a copy sql dump of your DB and the code you have and send it to [email protected] I can take a look at it. Quote Link to comment https://forums.phpfreaks.com/topic/288939-dependable-dropdownlist-phpmysqlajax/#findComment-1481803 Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.