最近工作当中再一次遇到要实现一个车辆列表,要求能够像微信通讯录一样,实现右侧滑动,点击功能,并且滑动过程中,能够有提示。原来用jquery实现过一次,为了精简代码,现在用原生的实现一次。想必工作中大家都能用上,所以就临时谢了一个小案例,分享给大家。本案例重在分享移动端的实现思路,代码和样式可能没有优化,大家见谅。
原本微信通讯录效果:
本案例效果图:
实际工作中可以实现类似于城市列表,产品字母排序这种需求:
代码展示
Dom
Dom结构仅供参考,实际情况看自己需求,比如我现在工作当中使用的React框架,这个静态的dom结构肯定不适用,不过万变不离其宗,原理都是通过id实现的。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <script src="/UploadFiles/2021-04-02/flexible_css.js">css
#letters { width: 0.3rem; position: fixed; //固定定位很关键,一般右侧都是固定的 right: 0.2rem; top: 50%; z-index: 999; -webkit-transform: translateY(-50%); -moz-transform: translateY(-50%); -ms-transform: translateY(-50%); -o-transform: translateY(-50%); transform: translateY(-50%); color: #B2B2B2; -webkit-border-radius: 0.1rem; -moz-border-radius: 0.1rem; border-radius: 0.1rem; background-color: #efefef; } #letters li { background-color: #efefef; display: block; text-align: center; width: 0.4rem; height: 0.4rem; line-height: 0.4rem; font-size: 0.3rem; text-align: center; } .list-container #namesList dt { font-size: 0.65rem; background-image: linear-gradient(-90deg, #ffffff 0%, #F1F3F6 100%); padding-left: 0.2rem; } .list-container #namesList dd { padding-left: 0.2rem; line-height: 0.8rem; font-size: 0.46rem; } .tip { width: 1rem; height: 1rem; line-height: 1rem; text-align: center; position: fixed; margin: 0 auto; z-index: 999; left: 50%; top: 50%; -webkit-transform: translate(-50%, -50%); -moz-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); -o-transform: translate(-50%, -50%); transform: translate(-50%, -50%); background-color: rgba(0, 0, 0, 0.38); -webkit-border-radius: 0.2rem; -moz-border-radius: 0.2rem; border-radius: 0.2rem; font-size: 0.6rem; color: #ffffff; display: none; }JS
这里的点击跳转并没有用a标签的跳转实现,而是使用了 element.scrollIntoView() 的方式实现,这样可以有效的避免点击后url上添加#的尴尬。
<script> let tipDom = document.querySelector(".tip") // 获取右侧字母DOM let letterDom = document.querySelector("#letters") // 右侧字母触摸判断逻辑 letterDom.addEventListener('touchmove', function (e) { e.preventDefault() //坐标(获取当前触控点的坐标) let y = e.touches[0].clientY let x = e.touches[0].clientX //根据当前纵向坐标控制内容的位置 let MaxL = letterDom.getBoundingClientRect().left; let MaxR = letterDom.getBoundingClientRect().right; let MaxT = letterDom.getBoundingClientRect().top let MaxB = letterDom.getBoundingClientRect().top + letterDom.getBoundingClientRect().height; // 判断是否从一个字母到另一个字母 if ((x >= MaxL && x <= MaxR) && (y >= MaxT && y <= MaxB) && x && y) { let ele = document.elementFromPoint(x, y) let eleContent = ele.innerHTML clickLetter(eleContent) tipDom.innerHTML = eleContent tipDom.style.display = 'block' letterDom.style.background = "#B2B2B2" letterDom.style.color = "#fff" } letterDom.removeEventListener("touchend", this, false) }) letterDom.addEventListener("touchend", function (e) { tipDom.style.display = "none" letterDom.style.background = "" letterDom.style.color = "#B2B2B2" letterDom.removeEventListener("touchmove", this, false) }) let letterDoms = document.querySelectorAll('#letters>.letter-item') for (let i = 0; i < letterDoms.length; i++) { const letterDom = letterDoms[i]; let letterTmp = letterDom.innerHTML letterDom.addEventListener('click',function () { clickLetter(letterTmp) }) } // 右侧字母点击事件 function clickLetter(letter) { let tmpLetter = letter.toLowerCase() let element = window.document.getElementById(tmpLetter) element.scrollIntoView() } </script>详细源码GitHub地址:WeChatAddressList
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 【雨果唱片】中国管弦乐《鹿回头》WAV
- APM亚流新世代《一起冒险》[FLAC/分轨][106.77MB]
- 崔健《飞狗》律冻文化[WAV+CUE][1.1G]
- 罗志祥《舞状元 (Explicit)》[320K/MP3][66.77MB]
- 尤雅.1997-幽雅精粹2CD【南方】【WAV+CUE】
- 张惠妹.2007-STAR(引进版)【EMI百代】【WAV+CUE】
- 群星.2008-LOVE情歌集VOL.8【正东】【WAV+CUE】
- 罗志祥《舞状元 (Explicit)》[FLAC/分轨][360.76MB]
- Tank《我不伟大,至少我能改变我。》[320K/MP3][160.41MB]
- Tank《我不伟大,至少我能改变我。》[FLAC/分轨][236.89MB]
- CD圣经推荐-夏韶声《谙2》SACD-ISO
- 钟镇涛-《百分百钟镇涛》首批限量版SACD-ISO
- 群星《继续微笑致敬许冠杰》[低速原抓WAV+CUE]
- 潘秀琼.2003-国语难忘金曲珍藏集【皇星全音】【WAV+CUE】
- 林东松.1997-2039玫瑰事件【宝丽金】【WAV+CUE】