微信小程序之拖拽排序(代码分享)


Posted in Javascript onJanuary 21, 2017

index.wxml

<!--index.wxml-->
<view class="container">
 <view bindtap="box" class="box" >
 <view disable-scroll="true" wx:for="{{content}}" bindtouchmove="move" bindtouchstart="movestart" bindtouchend="moveend" data-index="{{item.id}}" data-main="{{mainx}}" class="main {{mainx == item.id? 'mainmove':'mainend'}}" style="left:{{start.x}}px; top:{{start.y}}px">{{item.content}}</view>
 </view>
</view>

index.js

//index.js
//获取应用实例
var app = getApp();
var x,y,x1,y1,x2,y2,index,currindex,n,yy;
var arr1 = [{content:11,id:1},{content:22,id:2},{content:33,id:3},{content:44,id:4},{content:55,id:5}];
Page({
 data: {
 mainx:0,
 content:[{content:11,id:1},{content:22,id:2},{content:33,id:3},{content:44,id:4},{content:55,id:5}],
 start:{x:0,y:0}
 },
 movestart:function(e){
 currindex = e.target.dataset.index;
  x = e.touches[0].clientX;
  y = e.touches[0].clientY;
  x1 = e.currentTarget.offsetLeft;
  y1 = e.currentTarget.offsetTop;
 },
 move:function(e){
 yy = e.currentTarget.offsetTop;
 x2 = e.touches[0].clientX-x+x1;
 y2 = e.touches[0].clientY-y+y1;
 this.setData({
  mainx:currindex,
  opacity:0.7,
  start:{x:x2,y:y2}
 })
 },
 moveend:function(){
 if(y2 != 0){
  var arr = [];
  for(var i=0; i<this.data.content.length; i++){
  arr.push(this.data.content[i]);
  }
  var nx = this.data.content.length;
  n=1;
  for(var k=2; k<nx; k++){
  if(y2>(52*(k-1)+k*2-26)){
   n=k;
  }
  }
  if(y2>(52*(nx-1)+nx*2-26)){
  n = nx;
  }
  console.log(arr);
  console.log(arr1)
  arr.splice((currindex-1),1);
  arr.splice((n-1),0,arr1[currindex-1]);
  arr1 = [];
  for(var m=0; m<this.data.content.length; m++){
  console.log(arr[m]);
  arr[m].id = m+1;
  arr1.push(arr[m]);
  }
  // console.log(arr1);
  this.setData({
  mainx:"",
  content:arr,
  opacity:1
  })
 }
 }
})

index.wxss

.container {
 height: 100%;
 display: flex;
 flex-direction: column;
 align-items: center;
 justify-content: space-between;
 padding: 200rpx 0;
 box-sizing: border-box;
} 
.box{width:300px; position: relative}
.main{width: 90%; height:50px; background: #eee; border: 1px solid #ccc; margin:2px auto; text-align: center; line-height: 50px;}
.mainmove{position: absolute; opacity: 0.7}
.maind{background: #fff; border:1px dashed #efefef;}
.mainend{position: static; opacity: 1;}

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
有效的捕获JavaScript焦点的方法小结
Oct 08 Javascript
关于javascript DOM事件模型的两件事
Jul 22 Javascript
浅谈Javascript事件处理程序的几种方式
Jun 27 Javascript
JavaScript 产生不重复的随机数三种实现思路
Dec 13 Javascript
js 数组操作之pop,push,unshift,splice,shift
Jan 29 Javascript
jQuery学习笔记之jQuery中的$
Jan 19 Javascript
基于javascript实现彩票随机数生成(简单版)
Apr 17 Javascript
浅析jquery数组删除指定元素的方法:grep()
May 19 Javascript
Bootstrap CSS布局之列表
Dec 15 Javascript
JavaScript中的垃圾回收与内存泄漏示例详解
May 02 Javascript
百度小程序自定义通用toast组件
Jul 17 Javascript
JavaScript中document.activeELement焦点元素介绍
Nov 27 Javascript
微信小程序 利用css实现遮罩效果实例详解
Jan 21 #Javascript
JavaScript数组去重的6个方法
Jan 21 #Javascript
微信小程序 scroll-view实现上拉加载与下拉刷新的实例
Jan 21 #Javascript
JS常用知识点整理
Jan 21 #Javascript
使用vue.js2.0 + ElementUI开发后台管理系统详细教程(一)
Jan 21 #Javascript
原生js实现可拖动的登录框效果
Jan 21 #Javascript
微信小程序 WebSocket详解及应用
Jan 21 #Javascript
You might like
php学习之数据类型之间的转换代码
2011/05/29 PHP
探讨PHP中this,self,parent的区别详解
2013/06/08 PHP
ThinkPHP 3.2 数据分页代码分享
2014/10/14 PHP
php实现随机生成易于记忆的密码
2015/06/19 PHP
php数字运算验证码的实现代码
2015/07/30 PHP
一个小型js框架myJSFrame附API使用帮助
2008/06/28 Javascript
浅谈jQuery中对象遍历.eq().first().last().slice()方法
2014/11/26 Javascript
Javascript 中创建自定义对象的方法汇总
2014/12/04 Javascript
javaScript中with函数用法实例分析
2015/06/08 Javascript
jQuery Mobile弹出窗、弹出层知识汇总
2016/01/05 Javascript
jQuery源码解读之extend()与工具方法、实例方法详解
2017/03/30 jQuery
Node.js 异步异常的处理与domain模块解析
2017/05/10 Javascript
Angular2学习教程之组件中的DOM操作详解
2017/05/28 Javascript
JavaScript复制内容到剪贴板的两种常用方法
2018/02/27 Javascript
浅谈vux之x-input使用以及源码解读
2018/11/04 Javascript
Jquery 动态添加元素并添加点击事件实现过程解析
2019/10/12 jQuery
vue 动态组件(component :is) 和 dom元素限制(is)用法说明
2020/09/04 Javascript
Vue使用screenfull实现全屏效果
2020/09/17 Javascript
vue组件中节流函数的失效的原因和解决方法
2020/12/02 Vue.js
[55:25]VGJ.T vs Optic Supermajor小组赛D组 BO3 第三场 6.3
2018/06/04 DOTA
python 创建一个空dataframe 然后添加行数据的实例
2018/06/07 Python
Python使用分布式锁的代码演示示例
2018/07/30 Python
python使用opencv对图像mask处理的方法
2019/07/05 Python
Python 使用 environs 库定义环境变量的方法
2020/02/25 Python
Python MOCK SERVER moco模拟接口测试过程解析
2020/04/13 Python
如何理解Python中的变量
2020/06/01 Python
法国发饰品牌:Alexandre De Paris
2018/12/04 全球购物
Saks Fifth Avenue澳洲/亚太地区:萨克斯第五大道精品百货店
2019/06/09 全球购物
上海天奕面试题笔试题
2015/04/19 面试题
启动一个线程是用run()还是start()
2016/12/25 面试题
汽车制造与装配专业自荐信范文
2014/01/02 职场文书
詹天佑教学反思
2014/04/30 职场文书
安全责任书
2015/01/29 职场文书
教育读书笔记
2015/07/02 职场文书
《颐和园》教学反思
2016/02/19 职场文书
试了下Golang实现try catch的方法
2021/07/01 Golang