微信小程序实现拖拽功能


Posted in Javascript onSeptember 26, 2019

微信小程序实现拖拽功能

<view class='collectBox' 
  bindtap='addCollect' 
  wx:if="{{write[0]+write[1] > 0}}" 
  bindtouchmove="touchmove" 
  catch:touchmove 
  style="left:{{write[0]}}px;top:{{write[1]}}px;">
  <image src='../../images/icon/addcollect.png'></image>
</view>
// pages/cateDetaile/cateDetaile.js
const app = getApp()
Page({
 
  /**
   * 页面的初始数据
   */
  data: {
    // 拖拽参数
    writePosition: [80, 90], //默认定位参数
    writesize: [0, 0],// X Y 定位
    window: [0, 0], //屏幕尺寸
    write: [0, 0], //定位参数
    scrolltop: 0,//据顶部距离
  },
 
  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    // 在页面中定义插屏广告
    let that = this;
    that.getSysdata();
  },
  //计算默认定位值
  getSysdata: function () {
    var that = this;
    wx.getSystemInfo({
      success: function (e) {
        that.data.window = [e.windowWidth, e.windowHeight];
        var write = [];
        write[0] = that.data.window[0] * that.data.writePosition[0] / 100;
        write[1] = that.data.window[1] * that.data.writePosition[1] / 100;
        console.log(write,45)
        that.setData({
          write: write
        }, function () {
          // 获取元素宽高
          wx.createSelectorQuery().select('.collectBox').boundingClientRect(function (res) {
            console.log(res.width)
            that.data.writesize = [res.width, res.height];
          }).exec();
        })
      },
      fail: function (e) {
        console.log(e)
      }
    });
  },
  //开始拖拽  
  touchmove: function (e) {
    var that = this;
    var position = [e.touches[0].pageX - that.data.writesize[0] / 2, e.touches[0].pageY - that.data.writesize[1] / 2 - this.data.scrolltop];
    that.setData({
      write: position
    });
  },
  onPageScroll(e) {
    this.data.scrolltop = e.scrollTop;
  },
})

总结

以上所述是小编给大家介绍的微信小程序实现拖拽功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
JavaScript修改css样式style
Apr 15 Javascript
File, FileReader 和 Ajax 文件上传实例分析(php)
Apr 27 Javascript
extjs实现选择多表自定义查询功能 前台部分(ext源码)
Dec 20 Javascript
js对列表中第一个值处理与jsp页面对列表中第一个值处理的区别详解
Nov 05 Javascript
js 获取浏览器版本以此来调整CSS的样式
Jun 03 Javascript
AngularJs 60分钟入门基础教程
Apr 03 Javascript
全面解析node 表单的图片上传
Nov 21 Javascript
C#实现将一个字符转换为整数
Dec 12 Javascript
JS中offset和匀速动画详解
Feb 06 Javascript
详解js创建对象的几种方法及继承
Apr 12 Javascript
说说如何使用Vuex进行状态管理(小结)
Apr 14 Javascript
微信小程序实现限制用户转发功能的实例代码
Feb 22 Javascript
vue用BMap百度地图实现即时搜索功能
Sep 26 #Javascript
layui.tree组件的使用以及搜索节点功能的实现
Sep 26 #Javascript
微信小程序点击列表跳转到对应详情页过程解析
Sep 26 #Javascript
vue+element tabs选项卡分页效果
Jun 29 #Javascript
layui实现根据table数据判断按钮显示情况的方法
Sep 26 #Javascript
vue+element表格导出为Excel文件
Sep 26 #Javascript
利用layer实现表单完美验证的方法
Sep 26 #Javascript
You might like
php不写闭合标签的好处
2014/03/04 PHP
关于laravel框架中的常用目录路径函数
2019/10/23 PHP
基于jQuery的淡入淡出可自动切换的幻灯插件
2010/08/24 Javascript
JSONP 跨域共享信息
2012/08/16 Javascript
用JQuery实现全选与取消的两种简单方法
2014/02/22 Javascript
用js设置下拉框为只读的小技巧
2014/04/10 Javascript
jQuery中parents()方法用法实例
2015/01/07 Javascript
js实现文字跟随鼠标移动而移动的方法
2015/02/28 Javascript
js检测判断日期大于多少天的方法
2015/05/04 Javascript
jquery实现简单实用的打分程序实例
2015/07/23 Javascript
关于javascript中dataset的问题小结
2015/11/16 Javascript
JavaScript数值千分位格式化的两种简单实现方法
2016/08/01 Javascript
JS打印组合功能
2016/08/04 Javascript
微信小程序 wx.uploadFile无法上传解决办法
2016/12/14 Javascript
Bootstrap实现基于carousel.js框架的轮播图效果
2017/05/02 Javascript
微信小程序tabBar底部导航中文注解api详解
2017/08/16 Javascript
vue实现动态列表点击各行换色的方法
2018/09/13 Javascript
详解微信小程序获取当前时间及日期的方法
2019/04/28 Javascript
vue组件命名和props命名代码详解
2019/09/01 Javascript
python中定义结构体的方法
2013/03/04 Python
python实现的二叉树算法和kmp算法实例
2014/04/25 Python
Django的信号机制详解
2017/05/05 Python
PyCharm无法引用自身项目解决方式
2020/02/12 Python
使用matplotlib动态刷新指定曲线实例
2020/04/23 Python
解决python图像处理图像赋值后变为白色的问题
2020/06/04 Python
Python基于unittest实现测试用例执行
2020/11/25 Python
HTML5 Canvas实现烟花绽放特效
2016/03/02 HTML / CSS
微软中国官方商城:Microsoft Store中国
2018/10/12 全球购物
应届毕业生简历自我评价
2014/01/31 职场文书
《春雨》教学反思
2014/04/24 职场文书
销售队伍口号
2014/06/11 职场文书
违章停车检讨书
2014/10/21 职场文书
合作与交流自我评价
2015/03/09 职场文书
施工员岗位职责范本
2015/04/11 职场文书
乡镇安全生产月活动总结
2015/05/08 职场文书
Python3 使用pip安装git并获取Yahoo金融数据的操作
2021/04/08 Python