原生JS实现微信通讯录
最近工作当中再一次遇到要实现一个车辆列表,要求能够像微信通讯录一样,实现右侧滑动,点击功能,并且滑动过程中,能够有提示。原来用jquery实现过一次,为了精简代码,现在用原生的实现一次。想必工作中大家都能用上,所以就临时谢了一个小案例,分享给大家。本案例重在分享移动端的实现思路,代码和样式可能没有优化,大家见谅。
原本微信通讯录效果:
实际工作中可以实现类似于城市列表,产品字母排序这种需求:
这里的点击跳转并没有用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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持来客网。