微信小程序左滑刪除效果的實現(xiàn)

今天我們說下微信小程序左滑刪除效果的實現(xiàn),現(xiàn)在市場上很多APP都在使用這個效果掷匠,一個listView頁面滥崩,向左滑動一條item時,右側(cè)會出現(xiàn)一個刪除或者其他的選項讹语,用戶體驗非常好钙皮,操作起來十分方便,今天我們使用微信小程序來實現(xiàn)這個效果.......

先看效果
要實現(xiàn)的效果

要實現(xiàn)的效果:
1,當向左滑動時株灸,item跟隨手指像左移動崇摄,同時右側(cè)出現(xiàn)兩個可點擊的按鈕
2,當滑動距離大于按鈕寬度一半松開手指時慌烧,item自動滑動到左側(cè)顯示出按鈕逐抑,小于一半時item自動回到原來的位置,隱藏按鈕屹蚊。

思路:

1厕氨,首先頁面每個item分為上下兩層,上面一層放置正常內(nèi)容汹粤,下面一層放置左滑顯示出的按鈕命斧,這個可以使用z-index來實現(xiàn)分層。
2嘱兼,item上層使用絕對定位国葬,我們操縱 left 屬性的值來實現(xiàn)像左移動。
3芹壕,我們通過微信小程序api提供的touch對象和3個有關(guān)手指觸摸的函數(shù)(touchstart汇四,touchmove,touchend)來實現(xiàn)item隨手指移動踢涌。

小程序api-touch對象
Paste_Image.png

由于比較簡單通孽,所以直接上代碼了,詳細的講解都在代碼的注釋中睁壁,首先看下頁面的布局

<!--這是一個item的代碼>
    <view class="address-item" wx:for="{{addressList}}" >
   <!--這里綁定了剛才說的3個函數(shù)分別為 touchS背苦,touchM touchE-->
    <!--這里注意這個  style="{{item.txtStyle}}" ,這是我們一會再js中 將要設(shè)置的樣式 -->
        <view style="{{item.txtStyle}}"  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è)為默認地址</view>
            <view class="del" data-addressid="{{item.address.ID}}" data-index="{{index}}" catchtap="delAddress">刪除</view>
        </view>
         <!--這里是左滑按鈕部分----end-->
    </view>

再看js代碼

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

結(jié)束牲阁!不足請指教

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末固阁,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子城菊,更是在濱河造成了極大的恐慌备燃,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件凌唬,死亡現(xiàn)場離奇詭異并齐,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進店門况褪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來撕贞,“玉大人,你說我怎么就攤上這事测垛∧笈颍” “怎么了?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵食侮,是天一觀的道長号涯。 經(jīng)常有香客問我,道長锯七,這世上最難降的妖魔是什么链快? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮眉尸,結(jié)果婚禮上域蜗,老公的妹妹穿的比我還像新娘。我一直安慰自己噪猾,他們只是感情好霉祸,可當我...
    茶點故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著畏妖,像睡著了一般脉执。 火紅的嫁衣襯著肌膚如雪疼阔。 梳的紋絲不亂的頭發(fā)上戒劫,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天,我揣著相機與錄音婆廊,去河邊找鬼迅细。 笑死,一個胖子當著我的面吹牛淘邻,可吹牛的內(nèi)容都是我干的茵典。 我是一名探鬼主播,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼宾舅,長吁一口氣:“原來是場噩夢啊……” “哼统阿!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起筹我,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤扶平,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后蔬蕊,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體结澄,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了麻献。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片们妥。...
    茶點故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖勉吻,靈堂內(nèi)的尸體忽然破棺而出监婶,到底是詐尸還是另有隱情,我是刑警寧澤齿桃,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布压储,位于F島的核電站,受9級特大地震影響源譬,放射性物質(zhì)發(fā)生泄漏集惋。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一踩娘、第九天 我趴在偏房一處隱蔽的房頂上張望刮刑。 院中可真熱鬧,春花似錦养渴、人聲如沸雷绢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽翘紊。三九已至,卻和暖如春藐唠,著一層夾襖步出監(jiān)牢的瞬間帆疟,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工宇立, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留踪宠,地道東北人。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓妈嘹,卻偏偏與公主長得像柳琢,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子润脸,可洞房花燭夜當晚...
    茶點故事閱讀 42,722評論 2 345

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,498評論 25 707
  • 內(nèi)容抽屜菜單ListViewWebViewSwitchButton按鈕點贊按鈕進度條TabLayout圖標下拉刷新...
    皇小弟閱讀 46,708評論 22 664
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫柬脸、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,022評論 4 62
  • 同一律:邏輯內(nèi)涵和外延必須同一毙驯,不然就是我們俗話說的抬杠 矛盾律:相互的否定的兩個觀點思想倒堕,肯定有一個是假的。 排...
    大夢張吉玲閱讀 209評論 0 0
  • 測評前尔苦,請閱讀以下說明涩馆。 【溫馨提示】 測評時行施,請注意看是要求多選,還是單選魂那。孩子選擇的圖片蛾号,有單選,多選兩種形式...
    家門口的成功教室閱讀 446評論 0 0