我知道之前曾有人问过这个问题,但是解决方案对我不起作用。我正在尝试将新的项目排序保存到数据库。
我已经大大简化了它,但这是它的基本思想。我有一个嵌入了可排序列表的表单。
<form id="itemlist"> <ul id="itemsort"> <li id="Item_1">Item<input type="hidden" name="itemid[]" value="itemsRowID01"/></li> <li id="Item_2">Item<input type="hidden" name="itemid[]" value="itemsRowID02"/></li> <li id="Item_3">Item<input type="hidden" name="itemid[]" value="itemsRowID03"/></li> <li id="Item_4">Item<input type="hidden" name="itemid[]" value="itemsRowID04"/></li> </ul> </form>
我已经加载了JQuery和JQuery UI,以下代码启用了可排序列表功能,并将项目ID和新排序顺序发布到php脚本中。“ editor”变量是在加载时设置的公共变量,它工作正常。排序工作正常,但是重新排序列表时,发布的neworder值似乎没有变化。
//sorting feature $("#itemsort").live('hover', function() { $("#itemsort").sortable({ opacity:.5, update : function () { var neworder = $('#itemsort').sortable('serialize'); var inputs = serializePost('#itemlist'); $.post("core/actions.php",{ 'order': editor, 'inputs': inputs, 'neworder': neworder},function(){ alert("Order saved.", 1); }); } }); });
在actions.php上…
if(isset($_POST['order'])){ //set a variable for each post $batchid = $_POST['inputs']['itemid']; parse_str($_POST['neworder'], $neworder); //count the number of entries to be ordered $count = count($batchid); //use the count to create an incremental loop for each item to be updated. $i=0; while ($i <= $count) { $query ="UPDATE {$_POST['order']} SET order=$neworder[item][$i] WHERE id=$batchid[$i]"; ++$i; } }
我不确定为什么我获得的每个商品的订单都不会改变。
有任何想法吗?
-L
$("#list").live('hover', function() { $("#list").sortable({ update : function () { var neworder = new Array(); $('#list li').each(function() { //get the id var id = $(this).attr("id"); //create an object var obj = {}; //insert the id into the object obj[] = id; //push the object into the array neworder.push(obj); }); $.post("pagewhereyouuselist.php",{'neworder': neworder},function(data){}); } }); });
然后在您的PHP文件中,或在此示例中为“ pagewhereyouuselist.php”
$neworderarray = $_POST['neworder']; //loop through the list of ids and update your db foreach($neworderarray as $order=>$id){ //you prob jave a connection already i just added this as an example $con = mysql_connect("host","username","password"); if (!$con){ die('Could not connect: ' . mysql_error()); } mysql_select_db("my_db", $con); mysql_query("UPDATE table SET order = {$order} WHERE id = {$id}"); mysql_close($con); }
应该这样做,我没有测试它,因为它是一个示例连接。我实际使用的实际脚本更特定于我的程序,这是显示概念的简化版本