国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

微信小程序實現左滑修改、刪除功能

來源:懂視網 責編:小OO 時間:2020-11-27 22:05:47
文檔

微信小程序實現左滑修改、刪除功能

本文實例為大家分享了微信小程序實現左滑修改、刪除的具體代碼,供大家參考,具體內容如下:wxml。<;view class="offer-item" wx:for-items='{{offerList}}'>;<。--這里綁定了剛才說的3個函數分別為 touchS,touchM touchE-->;<。--這里是左滑按鈕部分----start-->;<;view bindtap="delItem" class='posit fr isMove' hidden='{{。--這里是左滑按鈕部分----end-->;<;/view>;<;/view>wxss。
推薦度:
導讀本文實例為大家分享了微信小程序實現左滑修改、刪除的具體代碼,供大家參考,具體內容如下:wxml。<;view class="offer-item" wx:for-items='{{offerList}}'>;<。--這里綁定了剛才說的3個函數分別為 touchS,touchM touchE-->;<。--這里是左滑按鈕部分----start-->;<;view bindtap="delItem" class='posit fr isMove' hidden='{{。--這里是左滑按鈕部分----end-->;<;/view>;<;/view>wxss。

本文實例為大家分享了微信小程序實現左滑修改、刪除的具體代碼,供大家參考,具體內容如下

wxml:

<view class="offer-item" wx:for-items='{{offerList}}'>
 <!--這里綁定了剛才說的3個函數分別為 touchS,touchM touchE-->
 <!--這里注意這個 style="{{item.txtStyle}}" ,這是我們一會再js中 將要設置的樣式 -->
 <view style="{{item.txtStyle}}">
 <view class="offer-item-top fl clearfix" bindtouchstart="touchS" bindtouchmove="touchM" bindtouchend="touchE" data-index="{{index}}">
 <navigator bindtap='navigatorTo' data-index="{{item.id}}">
 <view class='content'>
 <view class='title clearfix'>
 <view class='fl'>
 {{item.title}}黨建項目報價表
 </view>
 <image src='../../images/right.png' class='fr'></image>
 </view>
 <view class='note clearfix'>
 <view class='price fl'>
 {{item.create_time}}
 </view>
 </view>
 </view>
 </navigator>
 </view>

 <!--這里是左滑按鈕部分----start-->
 <view bindtap="delItem" class='posit fr isMove' hidden='{{!item.isMove}}'>
 <view class="ref" data-offerid="{{item.id}}" data-index="{{item.id}}" catchtap="ref">
 <image src='../../images/ref.png'></image>
 </view>
 <view class="del" data-offerid="{{item.id}}" data-index="{{item.id}}" catchtap="del">
 <image src='../../images/default.png'></image>
 </view>
 </view>
 <!--這里是左滑按鈕部分----end-->
 </view>
</view>

wxss:

.offer-item {
 height: 150rpx;
 width: 100vw;
 overflow-x: hidden;
 border-bottom: 1px solid #f0f0f0;
}

.offer-item>view {
 position: absolute;
 /* width: calc(100% + 200rpx); */
 height: 150rpx; 
}

.offer-item .offer-item-top {
 height: 100%;
}

.offer-item .offer-item-top navigator {
 display: inline-block;
 width: 100vw; 
 height: 100%;
}

.offer-item .content {
 padding: 35rpx 30rpx;
 position: relative;
 height: calc(100% - 70rpx);
}

.offer-item .title .fl {
 display: inline-block;
 width: 78%;
 overflow: hidden;
 text-overflow: ellipsis;
 white-space: nowrap;
 font-size: 30rpx;
 color: #333;
}

.offer-item .title .fr {
 display: inline-block;
 width: 20rpx;
 height: 26rpx;
 margin-top: 5rpx;
}

.offer-item .note {
 position: absolute;
 left: 30rpx;
 bottom: 35rpx;
 width: calc(100vw - 60rpx);
 font-size: 24rpx;
 color: #999;
}

.offer-item .posit {
 width: 200rpx;
 height: 150rpx;
 line-height: 150rpx;
 text-align: center;
 display: none
}

.posit.isMove {
 display: inline-block;
 position: absolute;
}

.posit.isMove[hidden] {
 display: none
}

.offer-item .posit>view {
 display: inline-block;
 width: 100rpx;
}

.offer-item .posit>view:first-of-type {
 background-color: #FED847;
}

.offer-item .posit>view:last-of-type {
 background-color: #C71B1B;
}

.offer-item .posit image {
 display: inline-block;
 width: 36rpx;
 height: 36rpx;
}

js:

let len = 0; // 初次加載長度
let hadLastPage = false; // 判斷是否到最后一頁

var initdata = function (that) {
 var list = that.data.offerList
 for (var i = 0; i < list.length; i++) {
 list[i].txtStyle = "";
 list[i].isMove = false;
 }
 that.setData({ 
 offerList: list
 })
}

Page({
 data: {
 offerList: [

 ],
 delBtnWidth: 100, // 刪除按鈕寬度單位(rpx)
 },


 // 手指剛放到屏幕觸發
 touchS: function (e) {
 console.log("touchS" + e);
 // initdata(this);
 // 判斷是否只有一個觸摸點
 if (e.touches.length == 1) {
 this.setData({
 // 記錄觸摸起始位置的X坐標
 startX: e.touches[0].clientX
 });
 };
 return false;
 },

 // 觸摸時觸發,手指在屏幕上每移動一次,觸發一次
 touchM: function (e) {
 var that = this;
 initdata(that);
 if (e.touches.length == 1) {
 // 記錄觸摸點位置的X坐標
 var moveX = e.touches[0].clientX;
 // 計算手指起始點的X坐標與當前觸摸點的X坐標的差值
 var disX = that.data.startX - moveX;
 // delBtnWidth 為右側按鈕區域的寬度
 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.offerList;
 // 將拼接好的樣式設置到當前item中
 list[index].txtStyle = txtStyle;

 list[index].isMove = true;
 // 更新列表的狀態
 this.setData({
 offerList: list
 });
 }
 },
 touchE: function (e) {
 console.log( e);
 var that = this
 if (e.changedTouches.length == 1) {
 // 手指移動結束后觸摸點位置的X坐標
 var endX = e.changedTouches[0].clientX;
 // 觸摸開始與結束,手指移動的距離
 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.offerList;
 list[index].txtStyle = txtStyle;
 // 更新列表的狀態
 that.setData({
 offerList: list
 });
 }
 },

 /**
 * 
 */
 navigatorTo: function (event) {

 },

 /**
 * 刪除操作
 */
 del: function (e) {
 var that = this;
 var data = {
 id: e.currentTarget.dataset.index
 };
 wx.showModal({
 title: '',
 content: '確定選擇刪除么?',
 confirmColor: '#C71B1B',
 cancelColor: '#666666',
 success: function (res) {
 if (res.confirm) {
 utils.requestFun("接口url", data, 'POST', function (msg) {
 console.log(msg)

 wx.showToast({
 title: '刪除成功',
 icon: 'success',
 duration: 1500
 })
 var lists = that.data.offerList;
 var list1 = [];
 for (let i = 0; i < lists.length; i++) {
 if (lists[i].id != e.currentTarget.dataset.index) {
 list1.push(lists[i])
 }
 }
 len--;
 that.setData({
 offerList: list1
 })
 })
 } else if (res.cancel) {

 }
 }
 })
 },

 /**
 * 修改操作
 */
 ref: function (e) {
 wx.navigateTo({
 url: '修改頁面路徑?id=' + e.currentTarget.dataset.index,
 })
 },

 /**
 * 生命周期函數--監聽頁面加載
 */
 onLoad: function (options) {
 page = 0;
 this.loadList();
 },


 /**
 * 生命周期函數--監聽頁面初次渲染完成
 */
 onReady: function () {

 },

 /**
 * 生命周期函數--監聽頁面顯示
 */
 onShow: function () {

 },

 /**
 * 生命周期函數--監聽頁面隱藏
 */
 onHide: function () {

 },

 /**
 * 生命周期函數--監聽頁面卸載
 */
 onUnload: function () {
 hadLastPage = false;
 len = 0; 
 },

 /**
 * 頁面相關事件處理函數--監聽用戶下拉動作
 */
 onPullDownRefresh: function () {

 },

 /**
 * 頁面上拉觸底事件的處理函數
 */
 onReachBottom: function (event) {
 console.log("上拉事件")
 this.loadList();
 }, 

 /** 
 * 數據請求封裝
 */
 loadList: function (event) {
 if (hadLastPage != false) {
 wx.showToast({
 title: '到底啦',
 });
 return;
 }
 var that = this;
 // 顯示加載圖標 
 wx.showLoading({
 title: '玩命加載中',
 })

 let data = {
 length: len,
 openId: 'openid'
 };
 utils.requestFun("接口url", data, 'POST', function (msg) {

 if (msg.data.length != 0) {
 var lists = that.data.offerList;
 for (let i = 0; i < msg.data.length; i++) {
 msg.data[i].isMove = false;
 lists.push(msg.data[i]);
 }

 // len 
 len = len + msg.data.length;

 // 設置數據 
 that.setData({
 offerList: lists
 })
 } else {
 hadLastPage = true;
 }
 wx.hideLoading();
 })
 }

})

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

微信小程序實現左滑修改、刪除功能

本文實例為大家分享了微信小程序實現左滑修改、刪除的具體代碼,供大家參考,具體內容如下:wxml。<;view class="offer-item" wx:for-items='{{offerList}}'>;<。--這里綁定了剛才說的3個函數分別為 touchS,touchM touchE-->;<。--這里是左滑按鈕部分----start-->;<;view bindtap="delItem" class='posit fr isMove' hidden='{{。--這里是左滑按鈕部分----end-->;<;/view>;<;/view>wxss。
推薦度:
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 91久久精品国产亚洲 | 自拍偷自拍亚洲精品情侣 | 日韩电影一区二区 | 欧美在线一区二区三区不卡 | 久久亚洲精品中文字幕60分钟 | 国产一级一级一级成人毛片 | 妖精视频一区二区三区 | 亚洲永久精品一区二区三区 | 欧美日韩综合 | 日韩欧美亚洲综合一区二区 | 看全色黄大色大片免费久久 | 中文字幕第一页亚洲 | 欧美 日韩 国产在线 | 欧美日韩国产精品自在自线 | 三男一女的伦交动态图 | 亚洲黄色一区 | 国产在视频 | 日韩欧美一区在线观看 | 中文字幕欧美在线观看 | 亚洲国产日韩欧美在线as乱码 | 久久精品无遮挡一级毛片 | 黄大片在线观看 | 国产第十页 | 日本国产一区二区三区 | 欧美日韩国产亚洲一区二区三区 | 国产精品天天看大片特色视频 | 国产视频在 | 国产手机在线αⅴ片无码观看 | 国产一区精品在线观看 | 成人三级在线 | 亚洲欧美日韩精品 | 欧美日韩高清在线 | 欧美日韩高清一本大道免费 | 亚洲免费久久 | 亚洲高清在线观看视频 | 91频道 | 精品日韩在线观看 | 成人免费久久精品国产片久久影院 | 日韩在线视频网 | 在线一区二区三区 | 日韩高清一区 |