Cita:
Iniciado por masterpuppet Porque campo los estas ordenando?, estas seguro que el ajax actualiza bien el orden de los registros?
beuno lo deje como esta en el tutorial solo cambie la conexion y la tabla, probe con la tabla que muestran en el tutorial pero tampoco, sigue haciendo lo mismo... Alguna idea?
Código PHP:
Ver original<script type="text/javascript">
$(document).ready(function(){
$(function() {
$("#contentLeft ul").sortable({ opacity: 0.2, cursor: 'move', update: function() {
var order = $(this).sortable("serialize") + '&action=updateRecordsListings';
$.post("updateDB.php", order, function(theResponse){
$("#contentRight").html(theResponse);
});
}
});
});
});
</script>
</head>
<body>
<div id="contentWrap">
<div id="contentTop">
<p>To read more & download the demo files: <a href="http://www.webresourcesdepot.com/dynamic-dragn-drop-with-jquery-and-php">Dynamic Drag’n Drop With jQuery And PHP</a><br />
</p>
<p>Drag'n drop the items below. Their new positions are updated in the database with an Ajax request in the backend.<img src="arrow-down.png" alt="Arrow Down" width="32" height="32" /></p>
</div>
<div id="contentLeft">
<ul>
<?php
$query = "SELECT * FROM records ORDER BY recordListingID desc";
{
?>
<li id="recordsArray_<?php echo $row['recordID']; ?>"><?php echo $row['recordID'] . ". " . $row['recordText']; ?></li>
<?php } ?>
</ul>
</div>
<div id="contentRight">
<p>Array will be displayed here.</p>
<p> </p>
</div>
</div>
</body>
</html>
Código PHP:
Ver original<?php
require("db.php");
$updateRecordsArray = $_POST['recordsArray'];
if ($action == "updateRecordsListings"){
$listingCounter = 1;
foreach ($updateRecordsArray as $recordIDValue) {
$query = "UPDATE records SET recordListingID = " . $listingCounter . " WHERE recordID = " . $recordIDValue;
$listingCounter = $listingCounter + 1;
}
echo '<pre>';
echo '</pre>';
echo 'If you refresh the page, you will see that records will stay just as you modified.';
}
?>
Código SQL:
Ver originalSET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for records
-- ----------------------------
CREATE TABLE `records` (
`recordID` INT(11) NOT NULL AUTO_INCREMENT,
`recordText` VARCHAR(255) DEFAULT NULL,
`recordListingID` INT(11) DEFAULT NULL,
PRIMARY KEY (`recordID`)
);
-- ----------------------------
-- Records
-- ----------------------------
INSERT INTO `records` VALUES ('1', 'Once dropped, an Ajax query is activated', '3');
INSERT INTO `records` VALUES ('2', 'Dragging changes the opacity of the item', '2');
INSERT INTO `records` VALUES ('3', 'Returned array can be found at the right', '1');
INSERT INTO `records` VALUES ('4', 'It is very very easy', '4');