我开发了一个系统,所以我的客户端可以通过php表单将条目添加到mysql表中。他希望能够在任何给定时间排序(或重新排列)条目在网站上显示的顺序。我不能以任何特定的顺序显示它,他必须能够随意定制它。我不知道如何以用户友好的方式做到这一点。我找到的解决方案是基于类别(即:按字母顺序排序,按ID号排序等),这是行不通的,我需要它是100%可定制的,如果他只想移动一个他需要的项目至。任何想法都将不胜感激。
谢谢!
答案 0 :(得分:0)
您可以使用jquery ui或滚动自己的分拣机让用户拖放。如果需要保存,可以使用ajax将结果订单发送回服务器。
此解决方案除了您提到的其他搜索选项外,还可以使用,例如字母排序。
现场演示:https://plnkr.co/edit/8YIkN6idxc0d2cH4TbTf?p=preview
<!DOCTYPE html>
<html>
<head>
<script data-require="jquery@2.1.3" data-semver="2.1.3" src="https://code.jquery.com/jquery-2.1.3.min.js"></script>
<script src="https://code.jquery.com/ui/1.12.0-beta.1/jquery-ui.min.js"></script>
<style>
table,
th,
td {
text-align: center;
}
</style>
</head>
<body>
<h2>Drag and drop a row</h2>
<table style="width: 500px;">
<thead>
</thead>
<tbody>
<tr>
<td style="background-color: #41CCFA;">1</td>
</tr>
<tr>
<td style="background-color: #FA6F41;">2</td>
</tr>
<tr>
<td style="background-color: #3DFFA8;">3</td>
</tr>
<tr>
<td style="background-color: #70FA41;">4</td>
</tr>
<tr>
<td style="background-color: #FA4441;">5</td>
</tr>
</tbody>
</table>
<script>
var help = function(e, tr) {
var trch = tr.children();
var trcl = tr.clone();
trcl.children().each(function(i) {
$(this).width(trch.eq(i).width());
});
return trcl;
},
updateI = function(e, ui) {
$('tr td:first-child', ui.item.parent()).each(function(i) {
$(this).html(i + 1);
});
};
$("tbody").sortable({
helper: help,
stop: updateI
}).disableSelection();
</script>
</body>
</html>
新笔记: 我在评论中注意到你不想让普通用户使用这个功能。您可以在代码中添加检查,例如
if (user.authenticated) {
... code to make rows draggable
}
您可以使用代码中使用的任何内容切换user.authenticated,以了解允许用户使用拖放操作。
无论您最终使用什么解决方案,请在保存任何行顺序更改之前再次检查服务器上的用户身份验证。