iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >小程序如何实现侧滑删除功能
  • 217
分享到

小程序如何实现侧滑删除功能

2023-07-02 12:07:51 217人浏览 泡泡鱼
摘要

这篇“小程序如何实现侧滑删除功能”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“小程序如何实现侧滑删除功能”文章吧。页面布局&

这篇“小程序如何实现侧滑删除功能”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“小程序如何实现侧滑删除功能”文章吧。

页面布局

<view class='dialogue-box'>      <scroll-view scroll-y="true" >        <view class='top-list'>          <view class='standard_text1'>#</view>          <view class='standard_text2'>积分项目</view>          <view class='standard_text3'>标准分</view>          <view class='standard_text4' bindtap='AddIntegrationProject'>            <view class='standard_btn'>+</view>          </view>        </view>        <view wx:if="{{lists.length>0}}">          <view class='top-list'>            <view wx:for="{{lists}}" wx:key="{{index}}" class='main_item'>              <view bindtouchstart="touchS" bindtouchmove="touchM" bindtouchend="touchE" data-index='{{index}}'  class="inner txt">                <view class='standard_text1'>{{index+1}}</view>                <view class='standard_text2'>{{item.itemName}}</view>                <view class='standard_text3'>{{item.score}}分</view>                <view class='standard_text4'>                  <image class='standard_icon' bindtap='editStanderClick' data-item='{{item}}' src='{{BaseURL}}uploadFile/groupImages/edit-h3.png'></image>                </view>              </view>              <view data-index="{{index}}" bindtap='delectOrganizationTeamScoreStandard' data-id='{{item.ID}}' class="inner del">删除</view>            </view>          </view>        </view>        <view class='No-data' wx:else>          <image src='{{BaseURL}}uploadFile/groupImages/No-data.png'></image>          <view class='No-text'>亲!暂无您的上月积分记录!</view>        </view>      </scroll-view></view>

样式

 .standard_text1 {  height: 80rpx;  line-height: 80rpx;  float: left;  width: 60rpx;  font-size: 28rpx;  color: #3b3c42;  padding-left: 30rpx;} .standard_text2 {  line-height: 80rpx;  float: left;  width: 380rpx;  font-size: 28rpx;  color: #3b3c42;} .standard_text3 {  height: 80rpx;  line-height: 80rpx;  float: left;  width: 130rpx;  font-size: 28rpx;  color: #3b3c42;} .standard_text4 {  height: 80rpx;  line-height: 80rpx;  float: left;  width: 140rpx;  font-size: 28rpx;  color: #3b3c42;} .standard_btn {  height: 50rpx;  line-height: 50rpx;  float: left;  border: 1px solid #3891f8;  color: #3891f8;  width: 50rpx;  text-align: center;  font-size: 36rpx;  border-radius: 60px;  margin-top: 10rpx;   margin-left: 60rpx;} .standard_icon {  height: 60rpx;  width: 60rpx;  margin-top: 8rpx;  float: left;  margin-left: 55rpx;} .main_item {  float: left;  width: 100%;  background-color: #fff;  position: relative;  overflow: hidden;  height: 40px;  line-height: 40px;}.inner {  position: absolute;  top: 0;  width: 100%;  line-height: 80rpx;  height: 80rpx;  float: left;} .inner.txt {  background-color: #fff;  width: 100%;  z-index: 5;  transition: left 0.2s ease-in-out;  white-space: nowrap;  overflow: hidden;  text-overflow: ellipsis;} .inner.del {  background-color: #e64340;  width: 150rpx;  text-align: center;  z-index: 4;  right: 0;  color: #fff;} 

js

var app = getApp();Page({     data: {    currentTab: 0,    BaseURL: app.globalData.BaseURL, //图片后台    mDate: '',     delBtnWidth: 180 //删除按钮宽度单位(rpx)  },     onLoad: function(options) {    var that = this;    that.getOrganizationTeamScore(); //获取标准积分    // 获取系统宽高信息     wx.getSystemInfo({      success: function(res) {        that.setData({          winWidth: res.windowWidth,          winHeight: res.windowHeight        });      }    });    that.initEleWidth(); //侧滑删除S  },     touchS: function(e) {    if (e.touches.length == 1) {      this.setData({        //设置触摸起始点水平方向位置        startX: e.touches[0].clientX      });    }  },  touchM: function(e) {    if (e.touches.length == 1) {      //手指移动时水平方向位置      var moveX = e.touches[0].clientX;      //手指起始点位置与移动期间的差值      var disX = this.data.startX - moveX;      var delBtnWidth = this.data.delBtnWidth;      var txtStyle = "";      if (disX == 0 || disX < 0) { //如果移动距离小于等于0,文本层位置不变        txtStyle = "left:0px";      } else if (disX > 0) { //移动距离大于0,文本层left值等于手指移动距离        txtStyle = "left:-" + disX + "px";        if (disX >= delBtnWidth) {          //控制手指移动距离最大值为删除按钮的宽度          txtStyle = "left:-" + delBtnWidth + "px";        }      }      //获取手指触摸的是哪一项      var index = e.currentTarget.dataset.index      // var index = e.target.dataset.index;      var lists = this.data.lists;      lists[index].txtStyle = txtStyle;      //更新列表的状态      this.setData({        lists: lists      });    }  },   touchE: function(e) {    if (e.changedTouches.length == 1) {      //手指移动结束后水平位置      var endX = e.changedTouches[0].clientX;      //触摸开始与结束,手指移动的距离      var disX = this.data.startX - endX;      var delBtnWidth = this.data.delBtnWidth;      //如果距离小于删除按钮的1/2,不显示删除按钮      var txtStyle = disX > delBtnWidth / 2 ? "left:-" + delBtnWidth + "px" : "left:0px";      //获取手指触摸的是哪一项      var index = e.currentTarget.dataset.index      // var index = e.target.dataset.index;      var lists = this.data.lists;      lists[index].txtStyle = txtStyle;      //更新列表的状态      this.setData({        lists: lists      });    }  },   //获取元素自适应后的实际宽度  getEleWidth: function(w) {    var real = 0;    try {      var res = wx.getSystemInfoSync().windowWidth;      var scale = (750 / 2) / (w / 2); //以宽度750px设计稿做宽度的自适应      // console.log(scale);      real = Math.floor(res / scale);      return real;    } catch (e) {      return false;      // Do something when catch error    }  },   initEleWidth: function() {    var delBtnWidth = this.getEleWidth(this.data.delBtnWidth);    this.setData({      delBtnWidth: delBtnWidth    });  },   //点击删除按钮事件  delItem: function(e) {    //获取列表中要删除项的下标    var index = e.currentTarget.dataset.index    // var index = e.target.dataset.index;    var lists = this.data.lists;    //移除列表中下标为index的项    lists.splice(index, 1);    //更新列表的状态    this.setData({      lists: lists    });  },         getOrganizationTeamScore: function() {    var that = this;    wx.request({      header: {        "Content-Type": "application/x-www-fORM-urlencoded"      },      method: 'POST',      url: app.globalData.BaseURL + 'group/v1/getOrganizationTeamScore.html',      data: {        organizationTeamID: that.data.organizationTeamID,      },      success: function(res) {        wx.hideLoading();        console.log("获取积分标准", res.data)        var status = res.data.status;        var info = res.data.info        if (status.indexOf("SUCCESS") == 0) {          that.setData({            lists: info          })        } else {          wx.showToast({            title: '获取失败',            icon: 'none'          })        }      }    })  },     delectOrganizationTeamScoreStandard: function(e) {    var organizationTeamScoreStandardID = e.currentTarget.dataset.id;    var that = this;    wx.showModal({      title: '删除此条标准记录',      content: '是否删除?',      success: function(res) {        if (res.confirm) {          console.log('用户点击确定')          wx.request({            header: {              "Content-Type": "application/x-www-form-urlencoded"            },            method: 'POST',            url: app.globalData.BaseURL + 'group/v1/delectOrganizationTeamScoreStandard.do',            data: {              organizationTeamScoreStandardID: organizationTeamScoreStandardID,            },            success: function(res) {              var status = res.data.status;              var info = res.data.info              if (status.indexOf("SUCCESS") == 0) {                wx.showToast({                  title: '操作成功',                  icon: 'none'                })                that.getOrganizationTeamScore();              } else {                wx.showToast({                  title: '数据使用中,无法删除!',                  icon: 'none'                })              }            }          })        } else if (res.cancel) {          console.log('用户点击取消')        }      }    })  },     editStanderClick: function(e) {    var item = e.currentTarget.dataset.item;    wx.navigateTo({      url: '/pages/My/Groupmanagement/Leanapproach/Employeeperformance/IntegralStandard/AddIntegrationProject/AddIntegrationProject?organizationTeamID=' + this.data.organizationTeamID +        '&organizationTeamScoreStandardID=' + item.ID +        '&scoreStanderFixID=' + item.scoreStanderFixID +        '&itemName=' + item.itemName +        '&score=' + item.score +        '&unit=' + item.unit +        '&isEdit=1',    })  },   // 添加积分项目  AddIntegrationProject: function() {    wx.navigateTo({      url: '/pages/My/Groupmanagement/Leanapproach/Employeeperformance/IntegralStandard/AddIntegrationProject/AddIntegrationProject?organizationTeamID=' + this.data.organizationTeamID,      success: function(res) {},      fail: function(res) {},      complete: function(res) {},    })  },      onReady: function() {   },     onShow: function() {    var that = this;    that.getOrganizationTeamScore(); //标准制定  },     onHide: function() {   },     onUnload: function() {   },     onPullDownRefresh: function() {   },     onReachBottom: function() {   },     onShareAppMessage: function() {   }})

效果图

小程序如何实现侧滑删除功能

以上就是关于“小程序如何实现侧滑删除功能”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。

--结束END--

本文标题: 小程序如何实现侧滑删除功能

本文链接: https://www.lsjlt.com/news/341955.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++ 生态系统中流行库和框架的贡献指南
    作为 c++++ 开发人员,通过遵循以下步骤即可为流行库和框架做出贡献:选择一个项目并熟悉其代码库。在 issue 跟踪器中寻找适合初学者的问题。创建一个新分支,实现修复并添加测试。提交...
    99+
    2024-05-15
    框架 c++ 流行库 git
  • C++ 生态系统中流行库和框架的社区支持情况
    c++++生态系统中流行库和框架的社区支持情况:boost:活跃的社区提供广泛的文档、教程和讨论区,确保持续的维护和更新。qt:庞大的社区提供丰富的文档、示例和论坛,积极参与开发和维护。...
    99+
    2024-05-15
    生态系统 社区支持 c++ overflow 标准库
  • c++中if elseif使用规则
    c++ 中 if-else if 语句的使用规则为:语法:if (条件1) { // 执行代码块 1} else if (条件 2) { // 执行代码块 2}// ...else ...
    99+
    2024-05-15
    c++
  • c++中的继承怎么写
    继承是一种允许类从现有类派生并访问其成员的强大机制。在 c++ 中,继承类型包括:单继承:一个子类从一个基类继承。多继承:一个子类从多个基类继承。层次继承:多个子类从同一个基类继承。多层...
    99+
    2024-05-15
    c++
  • c++中如何使用类和对象掌握目标
    在 c++ 中创建类和对象:使用 class 关键字定义类,包含数据成员和方法。使用对象名称和类名称创建对象。访问权限包括:公有、受保护和私有。数据成员是类的变量,每个对象拥有自己的副本...
    99+
    2024-05-15
    c++
  • c++中优先级是什么意思
    c++ 中的优先级规则:优先级高的操作符先执行,相同优先级的从左到右执行,括号可改变执行顺序。操作符优先级表包含从最高到最低的优先级列表,其中赋值运算符具有最低优先级。通过了解优先级,可...
    99+
    2024-05-15
    c++
  • c++中a+是什么意思
    c++ 中的 a+ 运算符表示自增运算符,用于将变量递增 1 并将结果存储在同一变量中。语法为 a++,用法包括循环和计数器。它可与后置递增运算符 ++a 交换使用,后者在表达式求值后递...
    99+
    2024-05-15
    c++
  • c++中a.b什么意思
    c++kquote>“a.b”表示对象“a”的成员“b”,用于访问对象成员,可用“对象名.成员名”的语法。它还可以用于访问嵌套成员,如“对象名.嵌套成员名.成员名”的语法。 c++...
    99+
    2024-05-15
    c++
  • C++ 并发编程库的优缺点
    c++++ 提供了多种并发编程库,满足不同场景下的需求。线程库 (std::thread) 易于使用但开销大;异步库 (std::async) 可异步执行任务,但 api 复杂;协程库 ...
    99+
    2024-05-15
    c++ 并发编程
  • 如何在 Golang 中备份数据库?
    在 golang 中备份数据库对于保护数据至关重要。可以使用标准库中的 database/sql 包,或第三方包如 github.com/go-sql-driver/mysql。具体步骤...
    99+
    2024-05-15
    golang 数据库备份 mysql git 标准库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作