php - 保存菜单排序位置到后台

标签 php jquery mysql

简介

我目前使用 jQuery .sortable 函数,它非常有用。然而,这只是客户端,我想将新的排序位置存储到后端(mySQL 数据库)。

我使用数字字段存储排序顺序(并使用 SQL ORDER BY 检索)。

Menu text     Sorting ID
------------   ---------
Menu item #1 => 0
Menu item #2 => 1
Menu item #3 => 2
Menu item #4 => 3

当前的 HTML 代码

<!doctype html>

<html lang="en">
<head>
  <meta charset="utf-8" />
  <title>jQuery UI Sortable - Default functionality</title>
  <link rel="stylesheet" href="http://code.jquery.com/ui/1.10.2/themes/smoothness/jquery-ui.css" />
  <script src="http://code.jquery.com/jquery-1.9.1.js"></script>
  <script src="http://code.jquery.com/ui/1.10.2/jquery-ui.js"></script>
  <link rel="stylesheet" href="/resources/demos/style.css" />
  <style>
  #sortable { list-style-type: none; margin: 0; padding: 0; width: 60%; }
  #sortable li { margin: 0 3px 3px 3px; padding: 0.4em; padding-left: 1.5em; font-size: 1.4em; height: 18px; }
  #sortable li span { position: absolute; margin-left: -1.3em; }
  </style>
  <script>
  $(function() {
    $( "#sortable" ).sortable();
    $( "#sortable" ).disableSelection();
  });
  </script>
</head>
<body>

<ul id="sortable">
  <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Menu item #1</li>
  <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Menu item #2</li>
  <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Menu item #3</li>
  <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Menu item #4</li>
</ul>


</body>
</html>

Tinker.io 链接:http://tinker.io/b3f27

问题

现在,我如何将新位置存储到数据库中?向 sortable 添加一个 ID 并将其发回 php 脚本,这将查找两个排序位置并切换它们是我会做的,但我期待您的意见。

最佳答案

这是在更新后使用 AJAX 发送数据的基本思想:

JS:

$("#sortable").sortable({
  update : function () {
      var items = $('#sortable').sortable('serialize');
    $.get("sort.php?"+items);
  }
});

HTML:

<ul id="sortable">
  <li id="s_1" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Menu item #1</li>
  <li id="s_2" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Menu item #2</li>
  <li id="s_3" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Menu item #3</li>
  <li id="s_4" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Menu item #4</li>
</ul>

这里需要给每一个LI设置id,参见working demo

PHP:

<?php
var_dump($_GET);
?>

您可以找到更详细的答案here

关于php - 保存菜单排序位置到后台,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15920223/

相关文章:

javascript - Facebook 群组中的 "Seen By"功能

python - SQLAlchemy/MySQL 的表设计

php - Cakephp 测试数据库 - 模型问题

PHP 面包屑循环

php - WAMP 无法访问本地网络 403 Forbidden

jquery - 启用按钮,使用 jquery.load 检查复选框

jquery - 从 JavaScript 调用 CustomValidator 验证

php - 如何在 drupal 中创建 pdf 文件?

jquery - knockout 中的复选框绑定(bind)不适用于触发事件

php - 在 Notepad++ 中使用 MySQLi 函数需要包括哪些内容?