运用wxs制作微信小程序左滑功能和跳转,性能更优越
锲子
微信小程序自定义左滑功能加上跳转,换成以往,左滑功能的逻辑一般是在js中实现,但在拖动方面,性能并不是那么的流畅。如今,官方新扩展了一套脚本语言wxs,在IOS设备上运行,性能会比JS快2~20倍,至于安卓上运行效率无差异。
构思
结合wxs,做左滑功能主要分为三个步骤:拖动开始=>拖动中=>拖动结束
让我们看看,这三个步骤需要做好哪些工作?
拖动开始
- 获取触发事件点的坐标数据
- 将坐标数据存到组件中,“拖动中”和“拖动结束”这两步骤要用上
拖动中
- 拿到拖动开始时存储的坐标数据
- 获取每一个拖动点的坐标数据,计算出与拖动开始的坐标数据的横坐标之差
- 根据计算出的横坐标之差加上当前左滑的距离,设置该组件的样式
拖动结束
- 拿到拖动开始时存储的坐标数据
- 获取离开时触发点的坐标数据,计算出与拖动开始的坐标数据的横坐标之差
- 根据计算出的结果,判断拖动是向左还是向右?最好设置好该组件的样式
代码片段
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制作微信小程序左滑功能和跳转,性能更优越的更多相关文章
- 微信小程序左滑删除功能
效果图如下: wxml代码: <view class="container"> <view class="touch-item {{item.isTou ...
- 微信小程序左滑删除
<view class="touch-item {{item.isTouchMove ? 'touch-move-active' : ''}}" data-index=&qu ...
- 微信小程序左滑删除未操作有复位效果
1.wxml <!--pages/test/test.wxml--> <view class="page"> <movable-area class= ...
- 微信小程序左滑显示按钮demo
wxml结构(删除部分代码): <view class="chapter-item" wx:for="{{klgData}}" data-index=&q ...
- 微信小程序在线制作 自己制作微信小程序
小程序是个什么东西?怎么自己制作微信小程序?微信小程序在线制作难吗?最近老是听这类问题,耳朵都长茧子了. 百牛信息技术bainiu.ltd整理发布于博客园 接下来作为一个技术人员的角度就为大家分析一下 ...
- 微信小程序调用蓝牙功能控制车位锁
第一次学用微信小程序,项目需要,被逼着研究了一下,功能是调用微信小程序的蓝牙功能,连接上智能车位锁,控制升降,大概步骤及调用的小程序接口API如下: 1.打开蓝牙模块 wx.openBluetooth ...
- 微信小程序新闻列表功能(读取文件、template模板使用)
微信小程序新闻列表功能(读取文件.template) 不忘初心,方得始终.初心易得,始终难守. 在之前的项目基础上进行修改,实现读取文件内容作为新闻内容进行展示. 首先,修改 post.wxml 文件 ...
- 微信小程序实战 购物车功能
代码地址如下:http://www.demodashi.com/demo/12400.html 一.准备工作 软件环境:微信开发者工具 官方下载地址:https://mp.weixin.qq.com/ ...
- 微信小程序在线支付功能使用总结
最近需要在微信小程序中用到在线支付功能,于是看了一下官方的文档,发现要在小程序里实现微信支付还是很方便的,如果你以前开发过服务号下的微信支付,那么你会发现其实小程序里的微信支付和服务号里的开发过程如出 ...
随机推荐
- Java的一些基础知识深入
1.浅析Java中的final关键字: 2.Java中的static关键字解析: 3.探秘Java中String.StringBuilder以及StringBuffer: 4.Java内部类详解: 5 ...
- vue-cli脚手架项目本地阅览和在线阅览
一.需求 开发环境:当然啦,前提是你要完整检测整个项目无错误的运行:npm run dev 后项目在本地预览问题没有问题 二.服务器本地阅览 生产环境:项目制作完成后需执行npm run build操 ...
- CSS3新单位vw、vh、vmin、vmax使用详解
像 px.em 这样的长度单位大家肯定都很熟悉,前者为绝对单位,后者为相对单位.CSS3 又引入了新单位:vw.vh.vmin.vmax.下面对它们做个详细介绍. 新单位也成为视窗单位,视窗(View ...
- Django-admin站点管理的详细使用
使用Django的管理模块,需要按照如下步骤操作: 管理界面本地化 创建管理员 注册模型类 自定义管理页面 1 管理界面本地化 在settings.py中设置语言和时区 LANGUAGE_CODE = ...
- django html母版
08.12自我总结 django母版 一.母版写的格式 在需要导入的地方写 {% block 名字定义 %} {% endblock %} 二.导入模板 {% extends 'FUCK.html' ...
- Python之网络编程Socket
Python 提供了两个级别访问的网络服务.: 低级别的网络服务支持基本的 Socket,它提供了标准的 BSD Sockets API,可以访问底层操作系统Socket接口的全部方法. 高级别的网络 ...
- Spring Boot 入门(七):集成 swagger2
本片文章是基于前一篇写的,<Spring Boot 入门(六):集成 treetable 和 zTree 实现树形图>,本篇主要介绍了spring boot集成swagger2.关于swa ...
- dos命令创建批处理脚本
win+r 打开cmd 输入 copy con 1.bat 回车 进入编辑状态输入 @echo off echo xxxx Ctrl+z 结束编辑 会在当前目录生成一个bat文件
- python编程系列---多线程共享全局变量出现了安全问题的解决方法
多线程共享全局变量出现了安全问题的解决方法 当多线程共享全局变量时,可能出现安全问题,解决机制----互斥锁:即在在一段与全局变量修改相关的代码中,假设一个时间片不足以完成全局变量的修改,就在这段代码 ...
- 如何在CentOS6.4系统上安装KVM虚拟机
CentOS6.4系统上安装KVM虚拟机 备注:以下操作说明是经过实验验证后总结出来的笔录,有需要的朋友可以进行参考,以下是基于VMware12.5.2虚拟机版本上安装的实验环境. 一.安装KVM ...