zoukankan      html  css  js  c++  java
  • 列表左右滑动,左滑删除功能实现


    作者原创,转载请注明出处

    作者:刘冰华
    2016-12-9 12:55

    先瞅瞅效果,再决定是否继续看下去哈

    关键js代码如下:

     //关闭所有列表的的active
        closeLeftActive : function(sendUserId){
            var front__lists = this.data.front__lists,
                lists = this.data.lists,
                result;
            const fllen = front__lists.length,
                  llen = lists.length;
            
            for(var i = 0; i < fllen; i++){
                front__lists[i]['isMoveLeft'] = false;
                front__lists[i]['moveLeftX'] = 0;
                if(sendUserId && sendUserId == front__lists[i]['sendUserId']){
                    this.touchElement = {
                        t : 'front__lists',
                        i : i
                    }
                }
            }
            for(var i = 0; i < llen; i++){
                lists[i]['isMoveLeft'] = false;
                lists[i]['moveLeftX'] = 0;
                if(sendUserId && sendUserId == lists[i]['sendUserId']){
                    this.touchElement = {
                        t : 'lists',
                        i : i
                    }
                }
            }
            this.setData({
                front__lists : front__lists,
                lists : lists
            });        
        },
        moveX : 0,//全局点击按下时的X坐标
        touchElement : {},//当前点击的列表元素
        isRedirect : true,//是否松开时跳转,默认如果滑动未超过10像素,跳转至详情页
        //点击按下时
        listtouchStart : function(e){
            this.moveX = e.changedTouches[0].clientX;//获取当前点击按下时的的X坐标
            const senduserid = e.currentTarget.dataset.senduserid;//获取当前列表元素的ID
            this.closeLeftActive(senduserid);//关闭所有元素的滑动样式,并且获取到当前点击的元素在this.data中的位置
            this.isRedirect = true;//点击默认改成能跳转
        },
        //点击移动时
        listtouchMove : function(e){
            const moveX = e.changedTouches[0].clientX;//获取移动到新位置时的坐标
            var mx = this.moveX - moveX;//计算得到与按下时的X坐标移动多少像素
            if(mx > 10){//如果像素大于10像素
                this.isRedirect = false;//则不跳转       
                /**将新的位置赋值到全局data渲染页面, */    
                this.setData((function(ele,val,bool){
                    var obj = {};
                    obj[ele+'moveLeftX'] = val;//左移的值
                    obj[ele+'isMoveLeft'] = bool;//控制是否超过40像素,则直接添加active样式类
                    return obj;
                })(this.touchElement.t + '[' + this.touchElement.i +']', mx, (mx >= 40)));
            }else if(mx < 0){//如果是右滑,也不跳转
                this.isRedirect = false;
            }
    
        },
        //点击松开时
        listtouchEnd : function(e){
            if(this.isRedirect){//如果能跳转则跳转至新的详情页面
                const senduserid = e.currentTarget.dataset.senduserid;//获取参数
                wx.navigateTo({
                   url: 'dialog?sendUserId=' + senduserid
                });
                this.closeLeftActive();//初始化关闭所有打开的滑动效果
                return;
            }
            const moveX = e.changedTouches[0].clientX;
            var mx = this.moveX - moveX;
            if(mx < 40){//如果松开时位移小于40像素则回弹关闭
                this.closeLeftActive();
            }
        },
        //点击被取消时,如中途来电话了等,初始化关闭所有打开的滑动效果
        listtouchcancel : function(e){
            this.closeLeftActive();
        }
    

      

    页面wxml文档

        <view class="lists">
            <view class="contain">
                <block wx:for="{{lists}}" wx:key="{{item.sendUserId}}">
                    <view class="list">
                        <view class="list__content{{item.isMoveLeft ? ' active' : ''}}" style="left:-{{item.moveLeftX}}px;right:{{item.moveLeftX}}px;" data-sendUserId="{{item.sendUserId}}" catchtouchstart="listtouchStart" catchtouchend="listtouchEnd" catchtouchcancel="listtouchcancel" catchtouchmove="listtouchMove">
                            <view class="list__hd">
                                <image src="{{item.img}}"/>
                                <view class="list__msgnumber" wx:if="{{item.silence}}"></view>
                                <view wx:elif="{{item.msgNumber > 0}}" class="list__messagenumber">
                                    <text hidden="{{item.silence}}" style="font-size:{{item.msgNumber > 99 ? '17' : '22'}}rpx;">{{item.msgNumber > 99 ? '99+' : item.msgNumber}}</text>
                                </view>
                            </view>
                            <view class="list__bd">
                                <view class="list__h3">
                                    <text class="list__name{{item.isteam ? ' list__teamname' : ''}}">{{item.name}}</text>
                                    <text class="list__sendtime">{{item.sendtime}}</text>
                                </view>
                                <view class="list__p{{item.silence ? ' silence' : ''}}">{{(item.silence && item.msgNumber > 0) ? '['+item.msgNumber +'条]' : ''}}{{item.desc}}</view><image wx:if="{{item.silence}}" class="list__silence" src="/image/silence.png"></image>
                            </view>
                            <view class="list__ft">
                            
                            </view>
                        </view>
                       
                        <view class="list__bg_btns">
                            <view class="list__bg_btn_gray">{{item.isteam ? '取消关注' : '标为已读'}}</view>
                            <view class="list__bg_btn_red">删除</view>
                        </view>
                    </view>
                </block>
            </view>
        </view>
    

      有问题可以去专栏留言哈

    http://www.wxappclub.com/column/19

  • 相关阅读:
    【转】京东抢购服务高并发实践
    【转】聊聊高并发系统之队列术
    深入研究Clang(八) Clang代码阅读之打log读流程1
    【转】保证分布式系统数据一致性的6种方案
    TextureView实现视频播放
    Spring之FactoryBean
    支付宝系统架构
    【转】高并发系统之限流特技
    Go语言中new和make的区别
    Linux下安装Beego:go install: cannot install cross-compiled binaries when GOBIN is set
  • 原文地址:https://www.cnblogs.com/gubook/p/6149121.html
Copyright © 2011-2022 走看看