锲子

微信小程序自定义左滑功能加上跳转,换成以往,左滑功能的逻辑一般是在js中实现,但在拖动方面,性能并不是那么的流畅。如今,官方新扩展了一套脚本语言wxs,在IOS设备上运行,性能会比JS快2~20倍,至于安卓上运行效率无差异。

构思

结合wxs,做左滑功能主要分为三个步骤:拖动开始=>拖动中=>拖动结束

让我们看看,这三个步骤需要做好哪些工作?

拖动开始

  1. 获取触发事件点的坐标数据
  2. 将坐标数据存到组件中,“拖动中”和“拖动结束”这两步骤要用上

拖动中

  1. 拿到拖动开始时存储的坐标数据
  2. 获取每一个拖动点的坐标数据,计算出与拖动开始的坐标数据的横坐标之差
  3. 根据计算出的横坐标之差加上当前左滑的距离,设置该组件的样式

拖动结束

  1. 拿到拖动开始时存储的坐标数据
  2. 获取离开时触发点的坐标数据,计算出与拖动开始的坐标数据的横坐标之差
  3. 根据计算出的结果,判断拖动是向左还是向右?最好设置好该组件的样式

代码片段

index.wxs

// 拖动开始时的事件
function lwstart(event,ins){
console.log("拖动开始"); // 获取事件触发点的坐标数据
var touch = event.touches[0] || event.changedTouches[0]
//存储坐标数据,后期使用
var moveE = ins.getState();
moveE.startX = touch.pageX;
moveE.startY = touch.pageY; //默认左滑当前的距离,也要存储起来
if (!moveE.rX) {
moveE.rX = 0;
} } // 拖动中时的事件
function lwmove(event, ins) {
//获取到该组件的id
var id = event.currentTarget.dataset.id;
//组件实例
var node = ins.selectComponent(id);
if(node){ // 获取拖动点的坐标数据
var touch = event.touches[0] || event.changedTouches[0]
//拿出拖动开始时存储的数据
var moveE = ins.getState(); //计算拖动点与拖动开始时的触发点之间的横坐标之差
var gap = touch.pageX - moveE.startX; //获取左滑的距离(拖动中不存储这个数据,而是拖动结束来存储这个数据)
var left = moveE.rX; //为向左滑动做处理,开始设置左滑的距离
if (gap < 0) {
// 设置组件向左滑的距离
node.setStyle({
"transform": "translateX(" + (gap + left) + "px)"
})
} console.log("拖动中", (gap + left));
}
} // 拖动结束时的事件
function lwend(event, ins) {
console.log("拖动结束"); //获取到该组件的id
var id = event.currentTarget.dataset.id;
//组件实例
var node = ins.selectComponent(id);
if(node){ // 获取离开点的坐标数据
var touch = event.touches[0] || event.changedTouches[0]
//拿出拖动开始时存储的数据
var moveE = ins.getState();
var x = touch.pageX; //计算拖动点与拖动开始时的触发点之间的横坐标之差
var gap = x - moveE.startX; //重新设置左滑的距离(最大是左滑区域的宽度:80,最小是0)
//根据算出来的数据判断是右滑还是左滑?
console.log(gap, "gggg");
if (Math.floor(gap) == 0||Math.floor(gap)==-1) {
console.log("调用导航方法");
//跟点击事件差不多了
// 调用js里的方法跳转就行
ins.callMethod('navfn', {
id: id
})
}
else if (gap < 0) {
// 左滑
// 设置左滑最大距离
node.setStyle({
"transform": "translateX(-80px)"
}) // 存储左滑距离
moveE.rX = -80;
} else if (gap > 0) {
//右滑
//设置左滑最小距离
node.setStyle({
"transform": "translateX(0px)"
})
// 存储左滑距离
moveE.rX = 0;
}
} } module.exports={
lwstart:lwstart,
lwmove:lwmove,
lwend:lwend
}

index.wxml

<!-- 导入wxs -->
<wxs module="test" src="./index.wxs"></wxs>
<!-- 作者有点懒,样式全是内联样式 -->
<!-- 我设置了两种组件的具体宽度(屏幕宽度和左滑宽度) -->
<!-- 不允许横向滚动 -->
<scroll-view style="width:{{ww}}px;"> <view wx:for="{{2}}" style="margin:10px 0;display:flex;align-items:center;width:{{ww+80}}px;transition:transform .3s;" bindtouchstart="{{test.lwstart}}" bindtouchmove="{{test.lwmove}}" bindtouchend="{{test.lwend}}" id="move{{index}}" data-id="#move{{index}}">
<!-- 内容区域 -->
<view class="con" style="width:{{ww}}px;height:80px;background-color:blue;"> </view> <!-- 左滑区域 -->
<view class="left" style="width:80px;height:60px;background-color:red;"> </view>
</view>
</scroll-view>

index..js

let that;

Page({
data: {
ww:400
},
onLoad: function () {
that=this;
wx.getSystemInfo({
success: function(res) {
that.setData({
ww:res.windowWidth
})
},
})
},
navfn(e){
console.log(e,"跳转");
wx.navigateTo({
url: '../nav/nav?id='+e.id,
})
}
})

预览效果

代码片段链接:https://developers.weixin.qq.com/s/r89ejJmP7ncM

运用wxs制作微信小程序左滑功能和跳转,性能更优越的更多相关文章

  1. 微信小程序左滑删除功能

    效果图如下: wxml代码: <view class="container"> <view class="touch-item {{item.isTou ...

  2. 微信小程序左滑删除

    <view class="touch-item {{item.isTouchMove ? 'touch-move-active' : ''}}" data-index=&qu ...

  3. 微信小程序左滑删除未操作有复位效果

    1.wxml <!--pages/test/test.wxml--> <view class="page"> <movable-area class= ...

  4. 微信小程序左滑显示按钮demo

    wxml结构(删除部分代码): <view class="chapter-item" wx:for="{{klgData}}" data-index=&q ...

  5. 微信小程序在线制作 自己制作微信小程序

    小程序是个什么东西?怎么自己制作微信小程序?微信小程序在线制作难吗?最近老是听这类问题,耳朵都长茧子了. 百牛信息技术bainiu.ltd整理发布于博客园 接下来作为一个技术人员的角度就为大家分析一下 ...

  6. 微信小程序调用蓝牙功能控制车位锁

    第一次学用微信小程序,项目需要,被逼着研究了一下,功能是调用微信小程序的蓝牙功能,连接上智能车位锁,控制升降,大概步骤及调用的小程序接口API如下: 1.打开蓝牙模块 wx.openBluetooth ...

  7. 微信小程序新闻列表功能(读取文件、template模板使用)

    微信小程序新闻列表功能(读取文件.template) 不忘初心,方得始终.初心易得,始终难守. 在之前的项目基础上进行修改,实现读取文件内容作为新闻内容进行展示. 首先,修改 post.wxml 文件 ...

  8. 微信小程序实战 购物车功能

    代码地址如下:http://www.demodashi.com/demo/12400.html 一.准备工作 软件环境:微信开发者工具 官方下载地址:https://mp.weixin.qq.com/ ...

  9. 微信小程序在线支付功能使用总结

    最近需要在微信小程序中用到在线支付功能,于是看了一下官方的文档,发现要在小程序里实现微信支付还是很方便的,如果你以前开发过服务号下的微信支付,那么你会发现其实小程序里的微信支付和服务号里的开发过程如出 ...

随机推荐

  1. Win10下80端口被System占用导致Apache无法启动

    Windows10下80端口被PID为4的System占用导致Apache无法启动的分析与解决方案 方法/步骤     最近更新了Windows10,总体上来说效果还是蛮不错的,然而今天在开启Apac ...

  2. 43 道检验基础的 JavaScript 面试题

    导读 这两天的GitHub Trending repositories被一个名叫 javascript-questions的项目霸榜了,项目中记录了一些JavaScript题目. 文中有些点作者解释的 ...

  3. React的diff算法(译文)

    前言  此篇文章主要是因为在看Virtual DOM(虚拟DOM)的时候看到的主要讲的是实现Virtual Dom 的diff算法,原文地址:https://calendar.perfplanet.c ...

  4. Mac OS Catalina 如何删除自带的应用

    在新推送的系统升级过后,(博主系统是Mac OS Mojave 10.14)我们会发现,之前我们删除的令人讨厌的Mac自带应用又回来了,如果我们还按照之前百度的方式删除的话,参考: https://w ...

  5. ELK 学习笔记之 elasticsearch Shard和Segment概念

    Shard和segment概念: 转载: http://blog.csdn.net/likui1314159/article/details/53217750 Shard(分片) 一个Shard就是一 ...

  6. Solidity 编程实例--Blind Auction 盲拍

    接下来扩展前面的公开拍卖成为一个盲拍.盲拍的特点是拍卖结束以前没有时间压力.在一个透明的计算平台上创建盲拍系统听起来可能有些矛盾,但是加密算法能让你脱离困境. During the bidding p ...

  7. 常用css总结

    个人博客: https://chenjiahao.xyz 1.让网站快速变灰 html { filter: grayscale(100%);//IE浏览器 -webkit-filter: graysc ...

  8. openpyxl中遇到TypeError: 'generator' object is not subscriptable的问题和解决方案

    今天在搭建驱动数据框架用到了一个叫 openpyxl的包用来解析excel数据 随后就出现了TypeError: 'generator' object is not subscriptable的bug ...

  9. 使用lombok中的log

    idea中安装lombok插件 引入lombok依赖 <!-- https://mvnrepository.com/artifact/org.projectlombok/lombok --> ...

  10. java的动手动脑10月20日

    (1)动手动脑 该函数没有赋初值再就是如果类提供一个自定义的构造方法,将导致系统不在提供默认的构造方法. (2) public class test { /*** @param args*/publi ...