91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-08-26 15:37:36 來源:腳本之家 閱讀:160 作者:Jnst 欄目:web開發

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

比如說像這樣:

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

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

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

開始擼代碼~

假設我們有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" 
 
 data-index="{{index}}" 
 bindtouchstart='touchstart' 
 bindtouchmove='touchmove' 
 bindtouchend='touchend'
>{{item}}</view>

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

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

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

环江| 湟源县| 金沙县| 宽城| 金溪县| 高青县| 新民市| 洛阳市| 金沙县| 平果县| 长寿区| 荣成市| 闽侯县| 阳城县| 永德县| 武鸣县| 林州市| 读书| 罗甸县| 崇义县| 汝城县| 富锦市| 夏河县| 镇远县| 澎湖县| 屯门区| 于都县| 巴马| 许昌市| 双牌县| 满城县| 万宁市| 石河子市| 霍山县| 兴山县| 桃江县| 乐山市| 惠来县| 沂源县| 化州市| 阳信县|