微信小程序左滑刪除功能開發(fā)案例

直接進入正題哮针,我們需要做的就是通過手指滑動列表項后,右側(cè)出現(xiàn)刪除从隆;
比如說像這樣:


微信小程序:52魔都

向左邊滑動后出現(xiàn)如下的效果:


微信小程序:52魔都

開始擼代碼~
假設(shè)我們有N個列表項來自一個數(shù)組list诚撵,先確定基本的結(jié)構(gòu)

<view class="list" wx:for="{{list}}" wx:key>
    <view class="item">
        <view class="wrap">{{item}}</view>
        <view class="delete"><text>刪除</text></view>
    </view>
</view>

在item中分別放入wrap作為顯示項目內(nèi)容的容器,與delete刪除按鈕的容器键闺。
當我們手指向左滑動wrap時,wrap容器向左移動澈驼;此時delete從wrap容器之后顯示出來辛燥;換句話說我們喜歡wrap容器蓋住delete,使wrap默認在delete上方缝其。
沒錯挎塌,我們用樣式來實現(xiàn)效果。

.item{ position:relative; }
.wrap{ 
  position:absolute;z-index:2; top:0;left:0;
  backgorund:#fff;width:100%;height:100%;
}
.delete{ position:absolute;z-index:1; top:0;right:0;width:120rpx;height:100%;}

好了内边,這些我們需要的核心樣式榴都,為了wrap能100%蓋住delete,我們給到它寬高都是百分之百漠其,并且填充背景顏色是必然的嘴高,至于要怎么美化可自行添加需要的樣式。
基本的結(jié)構(gòu)就到這里了和屎,接下來我們?yōu)閣rap添加觸摸事件拴驮;

<view class="wrap" 
  data-index="{{index}}" 
  bindtouchstart='touchstart' 
  bindtouchmove='touchmove' 
  bindtouchend='touchend'
>{{item}}</view>

我們綁定了三個觸摸事件,分別是柴信,觸摸開始套啤,觸摸時移動以及觸摸結(jié)束。
同時有個wrap添加了data-index="{{index}}" 這樣我們就可以確定當前觸摸的列表項是哪一個随常。
接著我們來為他們添加對應(yīng)的方法潜沦。

  touchstart:function(e){
    this.setData({
      index: e.currentTarget.dataset.index,
      Mstart: e.changedTouches[0].pageX
    });
  }

通過touchstart方法我們將當前觸發(fā)事件元素的索引保存到index萄涯,并且獲得當前手指觸摸的坐標位置e.changedTouches[0].pageX;

e.changedTouches[0].pageX

屏幕的左上角的坐標為(0,0)唆鸡,離左上角的距離越大pageX的值也越大窃判。

下一步,當我們移動手指向左滑動時:

  touchmove: function (e) {
    //列表項數(shù)組
    let list = this.data.list;
    //手指在屏幕上移動的距離
    //移動距離 = 觸摸的位置 - 移動后的觸摸位置
    let move = this.data.Mstart - e.changedTouches[0].pageX;
    // 這里就使用到我們之前記錄的索引index
    //比如你滑動第一個列表項index就是0喇闸,第二個列表項就是1袄琳,···
    //通過index我們就可以很準確的獲得當前觸發(fā)的元素,當然我們需要在事前為數(shù)組list的每一項元素添加x屬性
    list[this.data.index].x = move > 0 ? -move : 0;
    this.setData({
      list: list
    });
  }

當移動后的觸摸位置小于最初觸發(fā)的位置時燃乍,說明手指是向左滑動唆樊,因為pageX越小就越向屏幕邊緣靠近;這個時候move就是wrap容器需要向左移動的距離刻蟹。
我們重寫list[this.data.index].x的值逗旁,并且將原有的list覆蓋,這樣我們在滑動的時候就能實時的看到元素跟隨手指移動的效果舆瘪;
這個時候我們可以發(fā)現(xiàn)片效,我們一直往左邊移動,wrap元素就會被推到屏幕的邊緣英古;這很明顯不是我們想要的效果淀衣,我們希望滑動到一定距離后就停止滑動,于是我們?yōu)槠涮砑幼詈笠粋€方法召调;

  touchend: function (e) {
    let list = this.data.list;
    let move = this.data.Mstart - e.changedTouches[0].pageX;
    list[this.data.index].x = move > 100 ? -180 : 0;
    this.setData({
      list: list
    });
  },

我們看到這個方法唯一的不同的地方是這一行

list[this.data.index].x = move > 100 ? -180 : 0

意思是當手指離開元素時膨桥,如果移動的距離大于100,那么元素將自動向左移動到180的距離唠叛,如果小于100那么元素將向右恢復(fù)只嚣。
接著我們給wrap元素添加style,這樣它就能獲得移動的距離x艺沼。
至于為什么要移動距離要除以2册舞,這個跟小程序使用rpx單位有關(guān)系;
之前我們寫100障般,-180是像素px调鲸,需要換算成rpx;
微信小程序開發(fā)尺寸單位文檔

設(shè)備 rpx換算px (屏幕寬度/750) px換算rpx (750/屏幕寬度)
iPhone5,1rpx = 0.42px,1px = 2.34rpx
iPhone6,1rpx = 0.5px,1px = 2rpx
iPhone6 Plus,1rpx = 0.552px,1px = 1.81rpx

我們看到基本是2倍的比例剩拢;

<view class="wrap" 
  style="transform:translateX({{item.x/2}}px);"
  data-index="{{index}}" 
  bindtouchstart='touchstart' 
  bindtouchmove='touchmove' 
  bindtouchend='touchend'
>{{item}}</view>

最后我們使用樣式為wrap元素添加過渡效果就基本完成了线得。

詳細案例請搜索微信小程序:52魔都
源碼地址:https://github.com/749264345/wechat-weapp-map

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市徐伐,隨后出現(xiàn)的幾起案子贯钩,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,104評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件角雷,死亡現(xiàn)場離奇詭異祸穷,居然都是意外死亡,警方通過查閱死者的電腦和手機勺三,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評論 3 399
  • 文/潘曉璐 我一進店門雷滚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人吗坚,你說我怎么就攤上這事祈远。” “怎么了商源?”我有些...
    開封第一講書人閱讀 168,697評論 0 360
  • 文/不壞的土叔 我叫張陵车份,是天一觀的道長。 經(jīng)常有香客問我牡彻,道長扫沼,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,836評論 1 298
  • 正文 為了忘掉前任庄吼,我火速辦了婚禮缎除,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘总寻。我一直安慰自己器罐,他們只是感情好,可當我...
    茶點故事閱讀 68,851評論 6 397
  • 文/花漫 我一把揭開白布废菱。 她就那樣靜靜地躺著技矮,像睡著了一般。 火紅的嫁衣襯著肌膚如雪殊轴。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,441評論 1 310
  • 那天袒炉,我揣著相機與錄音旁理,去河邊找鬼。 笑死我磁,一個胖子當著我的面吹牛孽文,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播夺艰,決...
    沈念sama閱讀 40,992評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼芋哭,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了郁副?” 一聲冷哼從身側(cè)響起减牺,我...
    開封第一講書人閱讀 39,899評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后拔疚,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體肥隆,經(jīng)...
    沈念sama閱讀 46,457評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,529評論 3 341
  • 正文 我和宋清朗相戀三年稚失,在試婚紗的時候發(fā)現(xiàn)自己被綠了栋艳。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,664評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡句各,死狀恐怖吸占,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情凿宾,我是刑警寧澤矾屯,帶...
    沈念sama閱讀 36,346評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站菌湃,受9級特大地震影響问拘,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜惧所,卻給世界環(huán)境...
    茶點故事閱讀 42,025評論 3 334
  • 文/蒙蒙 一骤坐、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧下愈,春花似錦纽绍、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至履因,卻和暖如春障簿,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背栅迄。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評論 1 272
  • 我被黑心中介騙來泰國打工站故, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人毅舆。 一個月前我還...
    沈念sama閱讀 49,081評論 3 377
  • 正文 我出身青樓西篓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親憋活。 傳聞我的和親對象是個殘疾皇子岂津,可洞房花燭夜當晚...
    茶點故事閱讀 45,675評論 2 359

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