亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

微信小程序左滑刪除功能開發案例詳解

2019-11-19 12:32:10
字體:
來源:轉載
供稿:網友

直接進入正題,我們需要做的就是通過手指滑動列表項后,右側出現刪除;

比如說像這樣:


向左邊滑動后出現如下的效果:


開始擼代碼~

假設我們有N個列表項來自一個數組list,先確定基本的結構

<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作為顯示項目內容的容器,與delete刪除按鈕的容器。

當我們手指向左滑動wrap時,wrap容器向左移動;此時delete從wrap容器之后顯示出來;換句話說我們喜歡wrap容器蓋住delete,使wrap默認在delete上方。

沒錯,我們用樣式來實現效果。

.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,我們給到它寬高都是百分之百,并且填充背景顏色是必然的,至于要怎么美化可自行添加需要的樣式。

基本的結構就到這里了,接下來我們為wrap添加觸摸事件;

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

我們綁定了三個觸摸事件,分別是,觸摸開始,觸摸時移動以及觸摸結束。

同時有個wrap添加了data-index="{{index}}" 這樣我們就可以確定當前觸摸的列表項是哪一個。

接著我們來為他們添加對應的方法。

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

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

e.changedTouches[0].pageX

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

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

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

當移動后的觸摸位置小于最初觸發的位置時,說明手指是向左滑動,因為pageX越小就越向屏幕邊緣靠近;這個時候move就是wrap容器需要向左移動的距離。

我們重寫list[this.data.index].x的值,并且將原有的list覆蓋,這樣我們在滑動的時候就能實時的看到元素跟隨手指移動的效果;
這個時候我們可以發現,我們一直往左邊移動,wrap元素就會被推到屏幕的邊緣;這很明顯不是我們想要的效果,我們希望滑動到一定距離后就停止滑動,于是我們為其添加最后一個方法;

 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那么元素將向右恢復。

接著我們給wrap元素添加style,這樣它就能獲得移動的距離x。

至于為什么要移動距離要除以2,這個跟小程序使用rpx單位有關系;

之前我們寫100,-180是像素px,需要換算成rpx;

微信小程序開發尺寸單位文檔

設備 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元素添加過渡效果就基本完成了。

源碼地址:https://github.com/749264345/wechat-weapp-map

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美在线观看www| 欧美性极品少妇精品网站| 中文字幕亚洲无线码在线一区| 麻豆成人在线看| 国产一区二区在线播放| 国内免费久久久久久久久久久| 国产精品久久电影观看| 情事1991在线| 国产精品亚洲欧美导航| 91精品在线播放| 国产综合视频在线观看| 日韩在线观看免费高清| 中文字幕亚洲综合久久| 欧美成人在线免费| 国产在线观看91精品一区| 久久精品视频在线播放| 亚洲视频在线观看视频| 日韩电影中文 亚洲精品乱码| 国产精品久久久久免费a∨| 在线播放国产一区中文字幕剧情欧美| 国产91露脸中文字幕在线| 久久国产精彩视频| 另类图片亚洲另类| 亚洲精品日产aⅴ| 国产精品女人久久久久久| 欧美激情喷水视频| 欧美另类老女人| 丰满岳妇乱一区二区三区| 国产精品久久久久久av下载红粉| 欧美电影在线观看高清| 日韩国产高清视频在线| 久久久精品免费视频| 国产成人激情视频| 中文字幕亚洲一区二区三区| 亚洲精品久久久久久下一站| 久久精品国产亚洲一区二区| 26uuu亚洲国产精品| 成人黄色短视频在线观看| 亚洲欧洲av一区二区| 久久综合五月天| 亚洲免费精彩视频| 中文日韩在线观看| 91精品免费久久久久久久久| 国产视频福利一区| 国产精品一区二区在线| 欧美最顶级的aⅴ艳星| 8x拔播拔播x8国产精品| 欧美视频一二三| 欧美性猛交xxxx乱大交极品| 亚洲综合在线播放| 国产精品影院在线观看| 欧美激情一区二区三区在线视频观看| 久久精品国产成人| 欧美肥臀大乳一区二区免费视频| 国产一区二区三区毛片| 国a精品视频大全| 亚洲视频自拍偷拍| 欧美性在线视频| 26uuu另类亚洲欧美日本老年| 亚洲精品国产精品久久清纯直播| 国产精品影片在线观看| 国产精品久久久av| 欧美性xxxxhd| 美女扒开尿口让男人操亚洲视频网站| 久久久久99精品久久久久| 国产精品亚洲片夜色在线| 日韩av电影手机在线| 不卡av日日日| 亚洲第一二三四五区| 国产精品久久久精品| 国产精品久久久久久一区二区| 欧美日韩国产在线播放| 久久6免费高清热精品| 精品色蜜蜜精品视频在线观看| 欧美大片在线影院| 精品久久久香蕉免费精品视频| 亚洲国语精品自产拍在线观看| 91精品久久久久| 中文字幕欧美精品在线| 久久久噜噜噜久久| 中文字幕亚洲欧美| 国产视频亚洲视频| 日韩中文字幕国产| 不卡伊人av在线播放| 97不卡在线视频| 成人有码在线播放| 亚洲综合国产精品| 欧美激情xxxx| 68精品久久久久久欧美| 国产久一一精品| 亚洲高清福利视频| 成人激情综合网| 国产精品视频999| 欧美大人香蕉在线| 国产成人精品日本亚洲专区61| 成人xvideos免费视频| 免费91麻豆精品国产自产在线观看| 精品欧美aⅴ在线网站| 96sao精品视频在线观看| 久久久久久久久久久久av| 日韩美女在线观看一区| 不卡av在线播放| 久久天天躁狠狠躁夜夜躁2014| 国产欧美亚洲精品| 俺去啦;欧美日韩| 亚洲综合国产精品| 国产精品夫妻激情| 国产精品久久久久久久久免费看| 九九精品在线视频| 成人av.网址在线网站| 国产美女被下药99| 欧美视频一区二区三区…| 国产99久久精品一区二区永久免费| 久久av中文字幕| 久久天天躁夜夜躁狠狠躁2022| 亚洲精品资源在线| 久久久久久久久久亚洲| 亚洲午夜色婷婷在线| 国产精品一区=区| 久久最新资源网| 国产精品影院在线观看| 国产成人啪精品视频免费网| 久久91精品国产91久久久| 91精品国产综合久久香蕉最新版| 欧美激情啊啊啊| 国产ts一区二区| 成人福利视频在线观看| 国产精品一区二区性色av| 亚洲国产精品va在看黑人| 国产亚洲激情视频在线| 久久久久国产精品免费| 在线播放日韩精品| 亚洲精品乱码久久久久久按摩观| 中国日韩欧美久久久久久久久| 国产国语videosex另类| 久久综合免费视频影院| 国产精品白丝jk喷水视频一区| 中文字幕在线国产精品| 欧美日韩中文在线| 国产精品亚洲片夜色在线| 久久久伊人欧美| 中文字幕亚洲情99在线| 九色精品免费永久在线| www.久久久久久.com| 亚洲aⅴ男人的天堂在线观看| 清纯唯美亚洲激情| 在线不卡国产精品| 亚洲香蕉成人av网站在线观看| 国产精品免费久久久| 91免费视频网站| 日韩精品免费在线播放| 亚洲free性xxxx护士hd| 国内免费久久久久久久久久久| 欧美激情三级免费| 91精品中国老女人| 欧美黑人巨大xxx极品| 97精品一区二区三区| 欧美丰满老妇厨房牲生活| 国内精品小视频在线观看| 亚洲成年网站在线观看| 日韩av在线网页| 亚洲综合社区网| 91久久精品美女高潮| 国语自产偷拍精品视频偷|