php接口实现拖拽排序功能

 更新时间:2018年04月23日 14:02:06   作者:chriiess  
列表拖拽排序是一个很常见的功能,在后端接口处理中经常会用到,今天小编给大家带来了php接口实现拖拽排序功能,感兴趣的朋友一起看看吧

列表拖拽排序是一个很常见的功能,但是后端接口如何处理却是一个令人纠结的问题

如何实现才能达到效率最高呢?

先分析一个场景,假如有一个页面有十条数据,所谓的拖拽就是在这十条数据来来回回的拖,但是每次拖动都会影响到其他数据例如把最后一条拖到最前面,那么后面九条就自动往后移,反之也是,嗯~~~

先想象一下,排序号是固定的,就好像有十把椅子,每个椅子都是固定在那里的,移动的是上面的人,这样就不会影响到其他页面的数据了而且每个人换的也是之前其他人的桌椅号码,这样也不用去想到底要加多少才能排在哪里。

接口设计:

//$ids 这十条数据的id集合,逗号隔开的字符串
//$oldIndex 原始位置,从0开始算
//$newIndex 要拖动的位置
function dragSort($ids,$oldIndex,$newIndex)
{
  //保证查找出来的数据跟前台提交的顺序一致,这里要order by field
  //id 主键 sort 排序值
  $sql = "select id,sort from 表名字 where id in ($ids) order by field(id, " . $ids . ") ";
  $list = "这里省略,就是去数据库找嘛";
  //id集合
  $idArr  = [];
  //排序集合
  $sortArr = [];
  foreach ($list as $item) {
    $idArr[]  = $item['id'];
    $sortArr[] = $item['sort'];
  }
  //记录要拖动的id
  $oldValue = $idArr[$oldIndex];
  //删除这个要拖动的id
  unset($idArr[$oldIndex]);
  //插入新的位置,并自动移位
  array_splice($idArr, $newIndex, 0, $oldValue);
  //重新设置排序
  $set = [];
  for ($i = 0; $i < count($idArr); $i++) {
     $set[$i]['id']  = $idArr[$i];
     $set[$i]['sort'] = $sortArr[$i];
   }
  //保存到数据库省略
}

总结

以上所述是小编给大家介绍的php接口实现拖拽排序功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • Yii使用CLinkPager分页实例详解

    Yii使用CLinkPager分页实例详解

    这篇文章主要介绍了Yii使用CLinkPager分页的方法,需要的朋友可以参考下
    2014-07-07
  • php图片水印添加、压缩、剪切的封装类实现

    php图片水印添加、压缩、剪切的封装类实现

    这篇文章主要介绍了php图片水印添加,压缩,剪切的封装类实现方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2015-09-09
  • thinkPHP5框架路由常用知识点汇总

    thinkPHP5框架路由常用知识点汇总

    这篇文章主要介绍了thinkPHP5框架路由常用知识点,整理汇总了thinkPHP5框架路由相关概念、原理及操作技巧,需要的朋友可以参考下
    2019-09-09
  • ThinkPHP5.0框架使用build 自动生成模块操作示例

    ThinkPHP5.0框架使用build 自动生成模块操作示例

    这篇文章主要介绍了ThinkPHP5.0框架使用build 自动生成模块操作,结合实例形式分析了thinkPHP5使用build自动生成模块的具体步骤、方法与相关操作注意事项,需要的朋友可以参考下
    2019-04-04
  • phpstorm远程连接服务器并实时更新发布代码(thinkphp6.0.7)

    phpstorm远程连接服务器并实时更新发布代码(thinkphp6.0.7)

    这篇文章主要介绍了phpstorm远程连接服务器并实时更新发布代码(thinkphp6.0.7),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • Laravel认证原理以及完全自定义认证详解

    Laravel认证原理以及完全自定义认证详解

    最近在学习laravel框架,所以下面这篇文章主要给大家介绍了关于Laravel认证原理以及完全自定义认证的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧
    2018-07-07
  • ThinkPHP3.1新特性之内容解析输出详解

    ThinkPHP3.1新特性之内容解析输出详解

    以往版本的ThinkPHP对于模板文件保存在数据库里面的情况下,无法进行模板文件读取的。这篇文章主要介绍了ThinkPHP3.1新特性的内容解析输出,需要的朋友可以参考下
    2014-06-06
  • PHP错误Warning: Cannot modify header information - headers already sent by解决方法

    PHP错误Warning: Cannot modify header information - headers alr

    这篇文章主要介绍了PHP错误Warning: Cannot modify header information - headers already sent by解决方法,需要的朋友可以参考下
    2014-09-09
  • PHP获取页面执行时间的方法(推荐)

    PHP获取页面执行时间的方法(推荐)

    这篇文章主要介绍了PHP获取页面执行时间的方法(推荐)的相关资料,需要的朋友可以参考下
    2016-12-12
  • PHP将URL转换成短网址的算法分享

    PHP将URL转换成短网址的算法分享

    短网址(Short URL)顾名思义就是在形式上比较短的网址。在Web 2.0的今天,不得不说这是一个潮流。目前已经有许多类似服务,借助短网址您可以用简短的网址替代原来冗长的网址,让使用者可以更容易的分享链接,下面来看看如何用PHP实现这个功能,有需要的朋友们可以参考。
    2016-09-09

最新评论