色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

JS如何實現封裝列表右滑動刪除收藏按鈕

瀏覽:89日期:2024-04-29 09:47:49

前言

列表右滑動展示刪除和收藏按鈕就類似微信或者美團餓了嗎的列表,右滑動出現指定的按鈕功能;

本來我是想把前幾年支付寶的一個機試題拿來講,奈何我記不太清題目,也找不到當時做的題了,所以只好將就一下那這個案例來講解,其實解題思路大致是一樣的,畢竟作為程序員最重要的不是會多少框架和會用api用的多熟練,設計思路才是最重要!

案例

JS如何實現封裝列表右滑動刪除收藏按鈕

這個界面相信大家都非常熟悉,很多時候一些封裝好的插件可以拿來用即可實現這個功能,算是比較大眾化,不過為了給不了解原理的小伙伴們講解,所以自己用dom手寫了一個,思路如下:

html部分

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0'> <title>支付寶前端機試題</title> <link rel='stylesheet' href='http://www.lshqa.cn/bcjs/css/index.css' rel='external nofollow' > <script src='http://www.lshqa.cn/bcjs/js/index.js'></script></head><body> <h2 class='title'>購物車</h2> <section class='shoppingList'></section></body></html>

JS部分

let initXY = [0,0];//記錄移動的坐標let isStop = false;//記錄是否禁止滑動let oldIndex = null;//記錄舊的下標let theIndex = null;//記錄新的下標function touchstart(event,index){ if(event.touches.length > 1) { isStop = true; return; } oldIndex = theIndex; theIndex = null; initXY = [event.touches[0].pageX,event.touches[0].pageY]; // console.log(initXY);}function touchmove(event,index){ if(event.touches.length > 1) return; let moveX = event.touches[0].pageX - initXY[0]; let moveY = event.touches[0].pageY - initXY[1]; if(isStop || Math.abs(moveX) < 5) return;//如果禁止滑動或者滑動的距離小于5就返回 if(Math.abs(moveY) > Math.abs(moveX)){ isStop = true; return; } if(moveX<0){ theIndex = index; isStop = true; }else if(theIndex && oldIndex === theIndex){ oldIndex =index; theIndex = null; isStop = true; setTimeout(()=>{oldIndex=null;},150);//設置150毫秒延遲來凸顯動畫效果,實際不加也可以 } // 這里用jq就不用循環了,但我懶得引,大家知道就好 let goods = document.getElementsByClassName('goodsInfo'); for(let i=0;i<goods.length;i++){ theIndex === i ? goods[i].classList.add('open') : goods[i].classList.remove('open'); }; // console.log(moveX,moveY);}function touchend(){ isStop = false;}

總結

實現的方法無非就是判斷觸碰的時候移動的坐標值再加上動畫,有興趣看源代碼的小伙伴可以到github下載:

https://github.com/13632756286/Sliding-menu

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

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 中国嫩模一级毛片 | 18在线网站 | 亚洲二区在线 | 久久频这里精品香蕉久久 | 女人张开双腿让男人桶爽免 | 亚洲另类激情综合偷自拍 | 一区二区三区视频 | 一区免费在线观看 | 美女视频黄.免费网址 | 久久久久久久99久久久毒国产 | 日韩在线视频免费 | 在线观看一区二区三区视频 | 日本二区免费一片黄2019 | 欧美亚洲日本 | 国内一级特黄女人精品片 | 欧美成人 综合网播九公社 欧美成人26uuu欧美毛片 | 久久欧美精品欧美九久欧美 | 国产视频网站在线观看 | 色综合精品 | 国产免费一区二区三区在线观看 | 草草影院地址 | 九九热视频在线免费观看 | 欧美18www| 国产精品成aⅴ人片在线观看 | 亚洲成av人片在线观看 | 最新亚洲国产有精品 | 国产精品午夜性视频网站 | 日本乱人伦在线观看免费 | 三级视频在线播放线观看 | 国产精品合集久久久久青苹果 | 国产精品久久一区二区三区 | 日本免费视| 国产成人在线视频观看 | 一级女性全黄久久生活片 | 欧洲美女a视频一级毛片 | 久久久亚洲欧美综合 | 国产美女做爰免费视 | 久久成人a毛片免费观看网站 | 欧美一区二区三区免费播放 | 亚洲国产成人99精品激情在线 | 一级成人黄色片 |