angular-ui-sortable实现可拖拽排序列表


Posted in Javascript onDecember 28, 2016

项目需求,添加列表可拖拽排序功能,谷歌了一下,找到一个Angular的插件:angular-ui-sortable,项目地址:https://github.com/angular-ui/ui-sortable

需要在之前引入jquery,和jquery-ui,否则无法使用。

我们要做的事情,加载数据,拖拽排序并输出当前顺序:

js代码:

<script src="../../jquery.js"></script>
<script src="../../jquery-ui.js"></script>
<script src="../../angular.js"></script>
<script src="ui-sortable/src/sortable.js"></script>
<script>
 angular.module("app", ["ui.sortable"])
  .controller("sortCtrl", function($scope, $timeout) {
   $scope.cannotSort = false;
   $scope.data = [{
    "name": "allen",
    "age": 21,
    "i": 0
   }, {
    "name": "bob",
    "age": 18,
    "i": 1
   }, {
    "name": "curry",
    "age": 25,
    "i": 2
   }, {
    "name": "david",
    "age": 30,
    "i": 3
   }];

   $scope.sortableOptions = {
    // 数据有变化
    update: function(e, ui) {
     console.log("update");
     //需要使用延时方法,否则会输出原始数据的顺序,可能是BUG?
     $timeout(function() {
      var resArr = [];
      for (var i = 0; i < $scope.data.length; i++) {
       resArr.push($scope.data[i].i);
      }
      console.log(resArr);
     })


    },

    // 完成拖拽动作
    stop: function(e, ui) {
     //do nothing
    }
   }
  })
</script>

html代码:

<body>
 <div ng-controller="sortCtrl">
  <ul ui-sortable="sortableOptions" ng-model="data">
   <li ng-repeat="item in data ">
    <span>{{item.name}}, {{item.age}}</span>
   </li>
  </ul>
 </div>
</body>

效果:

angular-ui-sortable实现可拖拽排序列表

我又另外添加了数据排序功能,不能直接使用orderBy筛选器,这样每次移动都会重新排序,需要使用orderByFilter和$watchCollection来实现效果,具体可查看地址:https://github.com/justforuse/Pro_Angular-demo/tree/master/draggable-list

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
用javascript实现画板的代码
Sep 05 Javascript
7个Javascript地图脚本整理
Oct 20 Javascript
JavaScript中自定义事件用法分析
Dec 23 Javascript
JavaScript返回0-1之间随机数的方法
Apr 06 Javascript
jQuery构造函数init参数分析
May 13 Javascript
JS采用绝对定位实现回到顶部效果完整实例
Jun 20 Javascript
js原生跨域_用script标签的简单实现
Sep 24 Javascript
微信端开发--登录小程序步骤
Jan 11 Javascript
在vue.js中使用JSZip实现在前端解压文件的方法
Sep 05 Javascript
Puppet的一些技巧
Sep 17 Javascript
layui实现多图片上传并限制上传的图片数量
Sep 26 Javascript
解读Vue组件注册方式
May 15 Vue.js
JS正则表达式之非捕获分组用法实例分析
Dec 28 #Javascript
JavaScript实现经典排序算法之插入排序
Dec 28 #Javascript
JavaScript实现经典排序算法之选择排序
Dec 28 #Javascript
详解js中常规日期格式处理、月历渲染和倒计时函数
Dec 28 #Javascript
JavaScript实现经典排序算法之冒泡排序
Dec 28 #Javascript
BootStrap Tooltip插件源码解析
Dec 27 #Javascript
获取当前月(季度/年)的最后一天(set相关操作及应用)
Dec 27 #Javascript
You might like
历史证明,懒惰才是推动科学发展技术进步的动力
2021/03/02 无线电
php文件上传的例子及参数详解
2013/12/12 PHP
php页面函数设置超时限制的方法
2014/12/01 PHP
ThinkPHP5.0框架控制器继承基类和自定义类示例
2018/05/25 PHP
基于jquery的Repeater实现代码
2010/07/17 Javascript
javascript 得到文件后缀名的思路及实现
2020/05/09 Javascript
深入理解JavaScript是如何实现继承的
2013/12/12 Javascript
JavaScript数组深拷贝和浅拷贝的两种方法
2014/04/16 Javascript
jquery实现滑屏大图定时收缩为小banner图片的广告代码
2015/09/02 Javascript
jquery通过扩展select控件实现支持enter或focus选择的方法
2015/11/19 Javascript
javascript学习笔记_浅谈基础语法,类型,变量
2016/09/19 Javascript
React数据传递之组件内部通信的方法
2017/12/31 Javascript
elementUI vue this.$confirm 和el-dialog 弹出框 移动 示例demo
2019/07/03 Javascript
原生js实现贪食蛇小游戏的思路详解
2019/11/26 Javascript
node爬取新型冠状病毒的疫情实时动态
2020/02/06 Javascript
python调用windows api锁定计算机示例
2014/04/17 Python
python中__call__方法示例分析
2014/10/11 Python
python实现基于SVM手写数字识别功能
2020/05/27 Python
TensorFlow神经网络优化策略学习
2018/03/09 Python
python机器学习之随机森林(七)
2018/03/26 Python
PyQt5实现拖放功能
2018/04/25 Python
python爬取淘宝商品销量信息
2018/11/16 Python
flask session组件的使用示例
2018/12/25 Python
python判断文件是否存在,不存在就创建一个的实例
2019/02/18 Python
python+tkinter实现学生管理系统
2019/08/20 Python
Python with关键字,上下文管理器,@contextmanager文件操作示例
2019/10/17 Python
自定义Django默认的sitemap站点地图样式
2020/03/04 Python
python实现梯度下降算法的实例详解
2020/08/17 Python
香港草莓网:Strawberrynet香港
2019/05/10 全球购物
Currentbody美国/加拿大:美容仪专家
2020/03/09 全球购物
网站美工岗位职责
2014/04/02 职场文书
单位工资证明范本
2015/06/12 职场文书
上级领导检查欢迎词
2015/09/30 职场文书
不要在HTML中滥用div
2021/05/08 HTML / CSS
HTML通过表单实现酒店筛选功能
2021/05/18 HTML / CSS
详解vue身份认证管理和租户管理
2021/05/25 Vue.js