小程序:列表item實(shí)現(xiàn)自定義左滑出現(xiàn)菜單【轉(zhuǎn)】

小編給大家分享一下微信小程序中如何實(shí)現(xiàn)左滑刪除效果储狭,相信大部分人都還不怎么了解垢乙,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲糊秆,下面讓我們一起去了解一下吧始衅!

先看效果


image.png

要實(shí)現(xiàn)的效果:

1冷蚂,當(dāng)向左滑動(dòng)時(shí),item跟隨手指像左移動(dòng)汛闸,同時(shí)右側(cè)出現(xiàn)兩個(gè)可點(diǎn)擊的按鈕

2蝙茶,當(dāng)滑動(dòng)距離大于按鈕寬度一半松開手指時(shí),item自動(dòng)滑動(dòng)到左側(cè)顯示出按鈕诸老,小于一半時(shí)item自動(dòng)回到原來的位置隆夯,隱藏按鈕。

思路:

1别伏,首先頁面每個(gè)item分為上下兩層蹄衷,上面一層放置正常內(nèi)容,下面一層放置左滑顯示出的按鈕厘肮,這個(gè)可以使用z-index來實(shí)現(xiàn)分層愧口。2,item上層使用絕對(duì)定位类茂,我們操縱 left 屬性的值來實(shí)現(xiàn)像左移動(dòng)耍属。

3,我們通過微信小程序api提供的touch對(duì)象和3個(gè)有關(guān)手指觸摸的函數(shù)(touchstart巩检,touchmove厚骗,touchend)來實(shí)現(xiàn)item隨手指移動(dòng)。

image.png

image.png

由于比較簡(jiǎn)單兢哭,所以直接上代碼了领舰,詳細(xì)的講解都在代碼的注釋中

.wxml

<!--這是一個(gè)item的代碼>
  <view class="address-item" wx:for="{{addressList}}" >
  <!--這里綁定了剛才說的3個(gè)函數(shù)分別為 touchS,touchM touchE-->
  <!--這里注意這個(gè)  迟螺,這是我們一會(huì)再js中 將要設(shè)置的樣式 -->
    <view  bindtouchstart="touchS" bindtouchmove="touchM" bindtouchend="touchE" data-index="{{index}}" class="address-item-top" >
     <!--中間無關(guān)的代碼已被我刪除-->
    </view>

     <!--這里是左滑按鈕部分----start-->
    <view bindtap="delItem" class="posit">
      <view class="editor" data-addressid="{{item.address.ID}}" catchtap="setDefaultAddress">設(shè)為默認(rèn)地址</view>
      <view class="del" data-addressid="{{item.address.ID}}" data-index="{{index}}" catchtap="delAddress">刪除</view>
    </view>
     <!--這里是左滑按鈕部分----end-->
  </view>

.js

Page({
 data:{
  addressList:[{"Contact":"鐘誠(chéng)","Mobile":13888888888,"Address":"江蘇省蘇州市工業(yè)園區(qū)創(chuàng)意產(chǎn)業(yè)園"},
{"Contact":"凹凸曼","Mobile":13666666666,"Address":"江蘇省蘇州市工業(yè)園區(qū)獨(dú)墅湖體育館"},
{"Contact":"圖傲曼","Mobile":13666666666,"Address":"江蘇省蘇州市工業(yè)園區(qū)獨(dú)墅湖體育館"}],
  editIndex:0,
  delBtnWidth:150//刪除按鈕寬度單位(rpx)
 },
 onLoad:function(options){},
 //手指剛放到屏幕觸發(fā)
 touchS:function(e){
  console.log("touchS"+e);
  //判斷是否只有一個(gè)觸摸點(diǎn)
  if(e.touches.length==1){
   this.setData({
    //記錄觸摸起始位置的X坐標(biāo)
    startX:e.touches[0].clientX
   });
  }
 },
 //觸摸時(shí)觸發(fā)冲秽,手指在屏幕上每移動(dòng)一次,觸發(fā)一次
 touchM:function(e){
   console.log("touchM:"+e);
  var that = this
  if(e.touches.length==1){
   //記錄觸摸點(diǎn)位置的X坐標(biāo)
   var moveX = e.touches[0].clientX;
   //計(jì)算手指起始點(diǎn)的X坐標(biāo)與當(dāng)前觸摸點(diǎn)的X坐標(biāo)的差值
   var disX = that.data.startX - moveX;
   //delBtnWidth 為右側(cè)按鈕區(qū)域的寬度
   var delBtnWidth = that.data.delBtnWidth;
   var txtStyle = "";
   if(disX == 0 || disX < 0){//如果移動(dòng)距離小于等于0矩父,文本層位置不變
    txtStyle = "left:0px";
   }else if(disX > 0 ){//移動(dòng)距離大于0劳跃,文本層left值等于手指移動(dòng)距離
    txtStyle = "left:-"+disX+"px";
    if(disX>=delBtnWidth){
     //控制手指移動(dòng)距離最大值為刪除按鈕的寬度
     txtStyle = "left:-"+delBtnWidth+"px";
    }
   }
   //獲取手指觸摸的是哪一個(gè)item
   var index = e.currentTarget.dataset.index;
   var list = that.data.addressList;
   //將拼接好的樣式設(shè)置到當(dāng)前item中
   list[index].txtStyle = txtStyle; 
   //更新列表的狀態(tài)
   this.setData({
    addressList:list
   });
  }
 },
 touchE:function(e){
   console.log("touchE"+e);
  var that = this
  if(e.changedTouches.length==1){
   //手指移動(dòng)結(jié)束后觸摸點(diǎn)位置的X坐標(biāo)
   var endX = e.changedTouches[0].clientX;
   //觸摸開始與結(jié)束,手指移動(dòng)的距離
   var disX = that.data.startX - endX;
   var delBtnWidth = that.data.delBtnWidth;
   //如果距離小于刪除按鈕的1/2浙垫,不顯示刪除按鈕
   var txtStyle = disX > delBtnWidth/2 ? "left:-"+delBtnWidth+"px":"left:0px";
   //獲取手指觸摸的是哪一項(xiàng)
   var index = e.currentTarget.dataset.index;
   var list = that.data.addressList;
   list[index].txtStyle = txtStyle; 
   //更新列表的狀態(tài)
   that.setData({
    addressList:list
   });
  }
 }

原文傳送門

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末刨仑,一起剝皮案震驚了整個(gè)濱河市郑诺,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌杉武,老刑警劉巖辙诞,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異轻抱,居然都是意外死亡飞涂,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門祈搜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來较店,“玉大人,你說我怎么就攤上這事容燕×撼剩” “怎么了?”我有些...
    開封第一講書人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵蘸秘,是天一觀的道長(zhǎng)官卡。 經(jīng)常有香客問我,道長(zhǎng)醋虏,這世上最難降的妖魔是什么寻咒? 我笑而不...
    開封第一講書人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮颈嚼,結(jié)果婚禮上毛秘,老公的妹妹穿的比我還像新娘。我一直安慰自己阻课,他們只是感情好熔脂,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著柑肴,像睡著了一般。 火紅的嫁衣襯著肌膚如雪旬薯。 梳的紋絲不亂的頭發(fā)上晰骑,一...
    開封第一講書人閱讀 49,166評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音绊序,去河邊找鬼硕舆。 笑死,一個(gè)胖子當(dāng)著我的面吹牛骤公,可吹牛的內(nèi)容都是我干的抚官。 我是一名探鬼主播,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼阶捆,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼凌节!你這毒婦竟也來了钦听?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤倍奢,失蹤者是張志新(化名)和其女友劉穎朴上,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體卒煞,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡痪宰,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了畔裕。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片衣撬。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖扮饶,靈堂內(nèi)的尸體忽然破棺而出具练,到底是詐尸還是另有隱情,我是刑警寧澤贴届,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布靠粪,位于F島的核電站,受9級(jí)特大地震影響毫蚓,放射性物質(zhì)發(fā)生泄漏占键。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一元潘、第九天 我趴在偏房一處隱蔽的房頂上張望畔乙。 院中可真熱鬧,春花似錦翩概、人聲如沸牲距。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽牍鞠。三九已至,卻和暖如春评姨,著一層夾襖步出監(jiān)牢的瞬間难述,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來泰國(guó)打工吐句, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留胁后,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓嗦枢,卻偏偏與公主長(zhǎng)得像攀芯,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子文虏,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344