久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

原生JS實(shí)現(xiàn)微信通訊錄

瀏覽:123日期:2022-06-20 11:55:45

最近工作當(dāng)中再一次遇到要實(shí)現(xiàn)一個(gè)車(chē)輛列表,要求能夠像微信通訊錄一樣,實(shí)現(xiàn)右側(cè)滑動(dòng),點(diǎn)擊功能,并且滑動(dòng)過(guò)程中,能夠有提示。原來(lái)用jquery實(shí)現(xiàn)過(guò)一次,為了精簡(jiǎn)代碼,現(xiàn)在用原生的實(shí)現(xiàn)一次。想必工作中大家都能用上,所以就臨時(shí)謝了一個(gè)小案例,分享給大家。本案例重在分享移動(dòng)端的實(shí)現(xiàn)思路,代碼和樣式可能沒(méi)有優(yōu)化,大家見(jiàn)諒。

原本微信通訊錄效果:

原生JS實(shí)現(xiàn)微信通訊錄

本案例效果圖:

原生JS實(shí)現(xiàn)微信通訊錄

實(shí)際工作中可以實(shí)現(xiàn)類似于城市列表,產(chǎn)品字母排序這種需求:

原生JS實(shí)現(xiàn)微信通訊錄

代碼展示

Dom

Dom結(jié)構(gòu)僅供參考,實(shí)際情況看自己需求,比如我現(xiàn)在工作當(dāng)中使用的React框架,這個(gè)靜態(tài)的dom結(jié)構(gòu)肯定不適用,不過(guò)萬(wàn)變不離其宗,原理都是通過(guò)id實(shí)現(xiàn)的。

<!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='http://m.baoyu77737.com/bcjs/js/flexible_css.js'></script> <script src='http://m.baoyu77737.com/bcjs/js/flexible.js'></script> <link rel='stylesheet' href='http://m.baoyu77737.com/bcjs/css/index.css' rel='external nofollow' > <title>原生js仿照微信通訊錄</title></head><body><!-- 右側(cè)|字母列表 --><ul id='letters'> <li class='letter-item'>A</li> <li class='letter-item'>B</li> <li class='letter-item'>C</li> <li class='letter-item'>D</li> <li class='letter-item'>E</li> ...</ul><!-- 人名單列表 --><div class='list-container'> <dl id='namesList'> <dt id=’a’>A</dt> <dd>aaa</dd> <dd>aaa</dd> ... <dt id='b'>B</dt> <dd>bbb</dd> <dd>bbb</dd> <dd>bbb</dd> ... <dt id='c'>C</dt> <dd>cccc</dd> <dd>cccc</dd> <dd>cccc</dd> <dd>cccc</dd> ... <dt id='d'>D</dt> <dd>dddd</dd> <dd>dddd</dd> <dd>dddd</dd> ... </dl></div><!--提示字母框--><div class='tip'>A</div></body></html>

css

#letters { width: 0.3rem; position: fixed; //固定定位很關(guān)鍵,一般右側(cè)都是固定的 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

這里的點(diǎn)擊跳轉(zhuǎn)并沒(méi)有用a標(biāo)簽的跳轉(zhuǎn)實(shí)現(xiàn),而是使用了 element.scrollIntoView() 的方式實(shí)現(xiàn),這樣可以有效的避免點(diǎn)擊后url上添加#的尷尬。

<script> let tipDom = document.querySelector('.tip') // 獲取右側(cè)字母DOM let letterDom = document.querySelector('#letters') // 右側(cè)字母觸摸判斷邏輯 letterDom.addEventListener(’touchmove’, function (e) { e.preventDefault() //坐標(biāo)(獲取當(dāng)前觸控點(diǎn)的坐標(biāo)) let y = e.touches[0].clientY let x = e.touches[0].clientX //根據(jù)當(dāng)前縱向坐標(biāo)控制內(nèi)容的位置 let MaxL = letterDom.getBoundingClientRect().left; let MaxR = letterDom.getBoundingClientRect().right; let MaxT = letterDom.getBoundingClientRect().top let MaxB = letterDom.getBoundingClientRect().top + letterDom.getBoundingClientRect().height; // 判斷是否從一個(gè)字母到另一個(gè)字母 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) }) } // 右側(cè)字母點(diǎn)擊事件 function clickLetter(letter) { let tmpLetter = letter.toLowerCase() let element = window.document.getElementById(tmpLetter) element.scrollIntoView() }</script>

詳細(xì)源碼GitHub地址:WeChatAddressList

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: 微信
相關(guān)文章:
主站蜘蛛池模板: 阜宁县| 历史| 北川| 兰西县| 阿克苏市| 隆化县| 江孜县| 曲麻莱县| 富顺县| 鄱阳县| 民丰县| 西平县| 溧阳市| 紫阳县| 锡林浩特市| 凤台县| 双流县| 冀州市| 新巴尔虎右旗| 抚宁县| 呼伦贝尔市| 南雄市| 忻城县| 尖扎县| 红原县| 稻城县| 凯里市| 贞丰县| 美姑县| 蓝山县| 塔河县| 娄烦县| 元朗区| 平安县| 荔浦县| 固镇县| 当雄县| 邓州市| 阜新市| 仁化县| 乡宁县|