返回顶部
首页 > 资讯 > 精选 >vue怎么实现左滑删除功能
  • 810
分享到

vue怎么实现左滑删除功能

2023-07-04 13:07:26 810人浏览 独家记忆
摘要

本篇内容介绍了“Vue怎么实现左滑删除功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!左滑删除,很多UI框架里有,比如Mint-UI, M

本篇内容介绍了“Vue怎么实现左滑删除功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

左滑删除,很多UI框架里有,比如Mint-UI, Muse-UI等,一开始我们就是用的这两个,但是我们需求是要:左滑的时候出现img然后来实现点击删除,如下:

vue怎么实现左滑删除功能

建议还是放到common下。

<template>  <div class="left-delete">    <div class="move"       @touchstart="_touchStart"       @touchmove="_touchMove"       @touchend="_touchEnd"       :>      <slot></slot>    </div>    <div class="deleteIcon" : @click.prevent="deleteItem(index)"></div>  </div></template><script>  export default {    props: {      index: Number    },    data() {      return {        startX: 0,    //触摸位置         moveX: 0,    //滑动时的位置         disX: 0,    //移动距离         txtStyle: '',        delWidth: 200,        top: '',        zIndex: 'z-index:-1',      }    },    methods: {      _touchStart: function(ev) {        ev = ev || event;        if(ev.touches.length == 1){          // 手指按下的时候记录按下的位置          this.startX = ev.touches[0].clientX;          console.log(this.startX)        }      },      _touchMove: function(ev) {        ev = ev || event;        if(ev.touches.length == 1) {          // 滑动过程中的实时位置          this.moveX = ev.touches[0].clientX          // 滑动过程中实时计算滑动距离          this.disX = this.startX - this.moveX;          // console.log('disX==>',this.disX)          // 如果是向右滑动或者只是点击,不改变滑动位置          if(this.disX < 0 || this.disX == 0) {            // console.log('没有移动');            this.txtStyle = "transfORM:translateX(0rem)";          }else if (this.disX > 0) {如果是向左滑动,则实时给这个根元素一个向左的偏移-left,当偏移量到达固定值delWidth时,固定元素的偏移量为 delWidth            this.txtStyle = "transform:translateX(-" + this.disX/100 + "rem)";            if (this.disX >= this.delWidth/100) {              this.txtStyle = "transform:translateX(-" + this.delWidth/100 + "rem)";              this.zIndex = "z-index:" + 10 + "rem";            }          }        }      },      _touchEnd: function(ev) {        if (event.changedTouches.length == 1) {          this.startX = 0;          this.zIndex = "z-index:" + -1 + "rem";          console.log(event.changedTouches[0].clientX)          // 手指移动结束后的水平位置          let endX = event.changedTouches[0].clientX;          // 触摸开始与结束,手指移动的距离          this.disX = this.startX - endX;          //如果距离小于删除按钮的1/2,不显示删除按钮        }      },      deleteItem: function(index) {        this.$emit('deleteItem', index);      }    }  }</script><style>  .left-delete{    width:100%;    height:100%;    position:relative;    z-index:2;  }  .move{    position: relative;  }  .deleteIcon{    width: 2rem;    height:100%;    position: absolute;    right:0;    top:0;    background:url(./../../assets/main/4.png) no-repeat;    background-size: contain;  }</style>

然后哪个页面需要,哪个页面引入就好。比如myCollect页面需要,那么如下:

<template>  <section class="myCollect"> <section>      <div v-for="(item,index) in collectionList">        <left-slider :index="index" @deleteItem="deleteItem">          <Financial :item="item" :index="index"></Financial>        </left-slider>      </div>    </section>  </section></template><script>  import api from './../../fetch/api';  import { mapGetters } from 'vuex';  import Financial from './../common/financial.vue';  import LeftSlider from './../common/leftSlider.vue';  export default {    name: 'MyCollect',    props: {      item: Object,      index: Number    },    components: {      Financial,      LeftSlider    },    data() {      return {      }    },    created() {      this.getCollectionList();    },    methods: {    },    computed: {        ...mapGetters([          'getContextPathSrc',          'sessionId',          'token'        ]),  },  methods: {    // 删除    deleteItem: function(index) {      api.commonApi('后台接口,请求数据')//此处api是封装的axiOS,详情看文章:vue2+vuex+axios即可          .then(res => {        console.debug("REQ_ADD_STORE.res.data.result -> " + res.data.result);      this.collectionList.splice(index, 1);    });    }  },  mounted() {  }  }</script>

Vue的优点

Vue具体轻量级框架、简单易学、双向数据绑定、组件化、数据和结构的分离、虚拟DOM、运行速度快等优势,Vue中页面使用的是局部刷新,不用每次跳转页面都要请求所有数据和dom,可以大大提升访问速度和用户体验。

“vue怎么实现左滑删除功能”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: vue怎么实现左滑删除功能

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

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

猜你喜欢
  • vue怎么实现左滑删除功能
    本篇内容介绍了“vue怎么实现左滑删除功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!左滑删除,很多UI框架里有,比如Mint-UI, M...
    99+
    2023-07-04
  • Android Recyclerview实现左滑删除功能
    本文实例为大家分享了Android Recyclerview实现左滑删除的具体代码,供大家参考,具体内容如下 1.先创建一个工具类 SlideRecyclerView public...
    99+
    2024-04-02
  • vue2如何实现左滑删除功能
    这篇文章主要介绍vue2如何实现左滑删除功能,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!左滑删除,很多UI框架里有,比如Mint-UI, Muse-UI等,一开始我们就是用的这两个...
    99+
    2024-04-02
  • vue项目实现左滑删除功能(完整代码)
    实现效果 代码如下 html <template> <div> <div class="biggestBox"> &...
    99+
    2024-04-02
  • 使用vue怎么实现左滑编辑与删除
    使用vue怎么实现左滑编辑与删除?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。安装   vue-touch npm insta...
    99+
    2023-06-15
  • vue怎么实现仿qq左滑置顶删除组件
    这篇文章主要讲解了“vue怎么实现仿qq左滑置顶删除组件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue怎么实现仿qq左滑置顶删除组件”吧!效果图:HTML代码:主要的html代码:&l...
    99+
    2023-07-04
  • uniapp怎么实现侧滑删除功能
    近年来,移动应用程序的用户体验已经成为了设计师和开发者越来越重视的领域。使用流畅、易于操作的界面成为应用程序赢得用户青睐的关键所在。侧滑删除作为用户体验的一部分,可以使应用程序的操作更加方便,使用户更快速地找到需要的内容,因此在各种应用程序...
    99+
    2023-05-14
  • vue 实现左滑图片验证功能
    目录前言一、安装二、使用前言 众所周知,网页中滑动图片验证一直是各大网站、移动端的主流校验方式,其主要作用是为了区分人和机器以及为了防止机器人程序暴力登录或攻击从而设置的一种安全保护...
    99+
    2023-05-14
    vue 左滑图片验证 vue 图片验证 vue 左滑验证
  • 微信小程序如何实现向左滑动删除功能
    这篇文章将为大家详细讲解有关微信小程序如何实现向左滑动删除功能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。微信小程序 向左滑动删除功能的实现实现效果图:实现代码:1、w...
    99+
    2024-04-02
  • 小程序滑动删除功能怎么实现
    本篇内容主要讲解“小程序滑动删除功能怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“小程序滑动删除功能怎么实现”吧!小程序滑动删除效果示例  每个列表项绑定touchstart和touch...
    99+
    2023-06-26
  • 如何用javascript实现左滑删除
    这篇文章主要讲解了“如何用javascript实现左滑删除”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何用javascript实现左滑删除”吧! ...
    99+
    2024-04-02
  • Android 实现左滑出现删除选项
    滑动删除的部分主要包含两个部分, 一个是内容区域(用于放置正常显示的view),另一个是操作区域(用于放置删除按钮)。默认情况下,操作区域是不显示的,内容区域的大小是填充整个容 器,操作区域始终位于内容区域的右面。当开始滑动的时候,整个容器...
    99+
    2023-05-31
    android 左滑 删除
  • vue如何实现左滑图片验证功能
    这篇“vue如何实现左滑图片验证功能”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue如何实现左滑图片验证功能”文章吧。一...
    99+
    2023-07-05
  • 小程序实现侧滑删除功能
    本文实例为大家分享了小程序实现侧滑删除的具体代码,供大家参考,具体内容如下 1.页面布局 <view class='dialogue-box'>       <sc...
    99+
    2024-04-02
  • Android仿QQ首页ListView左滑置顶、删除功能
     Android 仿QQ首页ListView左滑置顶、删除等实现源码,具体内容如下效果图实现源码:package com.duguang.baseanimation.ui.listivew.deletelistview; ...
    99+
    2023-05-30
  • vue移动端实现左滑编辑与删除的全过程
    前言 根据项目需要使用 Vue-touch 实现了一个vue移动端的左滑编辑和删除功能,废话不多说,先看效果图,然后上代码吧! 方法如下: 第一步:安装 &nb...
    99+
    2024-04-02
  • iOS自定义UITableView实现不同系统下的左滑删除功能详解
    前言 在我们的app开发当中,经常会用到UITableView 的左滑删除的功能,通常的话效果如下 但有时候系统现有的功能并不能完全满足我们的开发需求,这样就需要我们在其现有的...
    99+
    2022-05-18
    自定义 uitableview 左滑删除
  • Android程序开发之ListView 与PopupWindow实现从左向右滑动删除功能
    文章实现的功能是:在ListView的Item上从右向左滑时,出现删除按钮,点击删除按钮把Item删除。 看过文章后,感觉没有必要把dispatchTouchEvent()和...
    99+
    2022-06-06
    popupwindow listview Android
  • Android实现ListView左右滑动删除和编辑
    有时候,为了实现项目中的需求,完成设计好的用户交互体验,不的不把这些View重新改造成自己想要的效果。 Android原生的ListView是不支持左右滑动的,但是看到微信电话...
    99+
    2022-06-06
    listview Android
  • 小程序如何实现侧滑删除功能
    这篇“小程序如何实现侧滑删除功能”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“小程序如何实现侧滑删除功能”文章吧。页面布局&...
    99+
    2023-07-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作