成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

原生JS實現微信通訊錄

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

最近工作當中再一次遇到要實現一個車輛列表,要求能夠像微信通訊錄一樣,實現右側滑動,點擊功能,并且滑動過程中,能夠有提示。原來用jquery實現過一次,為了精簡代碼,現在用原生的實現一次。想必工作中大家都能用上,所以就臨時謝了一個小案例,分享給大家。本案例重在分享移動端的實現思路,代碼和樣式可能沒有優化,大家見諒。

原本微信通訊錄效果:

原生JS實現微信通訊錄

本案例效果圖:

原生JS實現微信通訊錄

實際工作中可以實現類似于城市列表,產品字母排序這種需求:

原生JS實現微信通訊錄

代碼展示

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='http://www.piao2010.com/bcjs/js/flexible_css.js'></script> <script src='http://www.piao2010.com/bcjs/js/flexible.js'></script> <link rel='stylesheet' href='http://www.piao2010.com/bcjs/css/index.css' rel='external nofollow' > <title>原生js仿照微信通訊錄</title></head><body><!-- 右側|字母列表 --><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; //固定定位很關鍵,一般右側都是固定的 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

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

標簽: 微信
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产成人免费视频精品含羞草妖精| 国产精品1区2区3区| 毛片av一区二区| 国产一区二区中文| 久久色在线观看| 成人一区在线看| 欧美猛男男办公室激情| 日本一区中文字幕| 老司机精品福利视频| 五月开心婷婷久久| 国产精品久久亚洲7777| 亚洲国产精品成人综合色在线婷婷| 精品亚洲免费视频| 久久免费一区| 亚洲资源中文字幕| 一区二区三区导航| 亚洲人亚洲人成电影网站色| av激情综合网| 久久综合999| av一区二区不卡| www久久久久| 91亚洲国产成人精品一区二三| 亚洲精品一区二区三区香蕉| 成人免费视频视频在线观看免费| 91精品国产综合久久久久久久 | 色婷婷av一区| 三级久久三级久久| 在线亚洲高清视频| 久久电影国产免费久久电影 | 国产精品jizz在线观看美国| 99精品视频免费观看视频| 高清国产一区二区| 日本视频中文字幕一区二区三区| 国产麻豆精品一区二区| 亚洲不卡在线观看| 久久综合网络一区二区| 久久久久久久综合色一本| 在线观看欧美日本| 午夜国产精品视频| 日韩精品影音先锋| 国产精品入口| 亚洲午夜av| 久久先锋资源网| 欧美性色综合网| 欧美影片第一页| 日韩亚洲欧美精品| 麻豆成人小视频| 久久永久免费| 日韩精品一区二| 亚洲精品成人a在线观看| 亚洲国产清纯| 亚洲福利一区二区三区| 欧美写真视频网站| 国产不卡视频一区| 欧美国产日本韩| 国产欧美日韩综合一区在线播放 | 欧美1区2区3区| 综合久久国产九一剧情麻豆| 香港久久久电影| 欧美aⅴ一区二区三区视频| 制服丝袜日韩国产| 色综合天天在线| 亚洲欧洲av色图| 性色一区二区三区| 精品系列免费在线观看| 精品日韩欧美在线| 国内一区二区三区| 亚洲国产色一区| 欧美日韩国产系列| 欧美区一区二| 午夜一区二区三区在线观看| 欧美日韩中文国产| 欧美呦呦网站| 亚洲一本大道在线| 欧美三级视频在线| 色综合视频在线观看| 亚洲一级二级三级| 欧美一级在线视频| 国产精品播放| 天堂av在线一区| 日韩区在线观看| 韩国亚洲精品| 奇米四色…亚洲| 精品久久一区二区三区| 亚洲国产日本| 精品一区二区三区久久| 久久久天堂av| 久久久精品动漫| 成人av在线电影| 亚洲丝袜制服诱惑| 色国产综合视频| 欧美影院一区| 免费在线观看视频一区| 久久久www成人免费毛片麻豆 | 精品亚洲成a人在线观看| 欧美国产日本韩| 欧美性欧美巨大黑白大战| 午夜电影亚洲| 久久99久久99精品免视看婷婷 | 日韩国产一二三区| 久久久久久久综合色一本| 欧美一级视频| av电影天堂一区二区在线观看| 亚洲午夜视频在线| 欧美精品一区二| 日本精品免费观看高清观看| 91麻豆文化传媒在线观看| 日本一区中文字幕| 中文在线免费一区三区高中清不卡| 久久综合图片| 欧美特黄视频| 久草这里只有精品视频| 中文字幕欧美一| 51午夜精品国产| 国产精品久久久久久久免费软件| 成人av网站在线观看| 日韩国产欧美三级| 国产精品久久久久四虎| 欧美日本在线看| 国产亚洲毛片| 91蜜桃网址入口| 精品一区二区三区免费视频| 亚洲手机成人高清视频| 欧美videos中文字幕| 在线观看中文字幕不卡| 日韩视频中文| 99久久婷婷国产| 老司机免费视频一区二区 | 激情成人综合网| 玉米视频成人免费看| 国产区在线观看成人精品| 91精品国产综合久久久久久漫画| 久久精品成人| 亚洲视频观看| 972aa.com艺术欧美| 国产综合色视频| 亚洲第一二三四区| 国产欧美日韩精品在线| 欧美一区二区三区视频在线| 免费永久网站黄欧美| 国产精品播放| 91麻豆国产福利在线观看| 国产在线观看免费一区| 亚洲电影激情视频网站| 国产精品久久久一本精品| 精品噜噜噜噜久久久久久久久试看 | 欧美另类变人与禽xxxxx| 亚洲欧美日韩在线综合| 欧美一区二视频在线免费观看| 国产精品自拍在线| 精品一区二区三区香蕉蜜桃| 亚洲成人午夜影院| 最新久久zyz资源站| 久久久五月婷婷| 日韩欧美国产一二三区| 欧美日韩亚洲综合一区二区三区 | 99久久国产综合精品麻豆| 国产伦精品一区二区三区在线观看| 亚洲成av人**亚洲成av**| 中文字幕亚洲成人| 久久精品视频免费| 精品欧美久久久| 日韩一区二区视频| 欧美喷潮久久久xxxxx| 91福利在线播放| 亚洲伊人网站| 国产亚洲欧美另类一区二区三区| 亚洲日本精品国产第一区| 国产一区高清视频| 欧美激情1区2区| 色综合久久中文字幕| 成人久久18免费网站麻豆| 国产精品一二二区| 久久99精品一区二区三区| 日韩成人一区二区三区在线观看| 一区二区三区国产精华| 亚洲精品视频自拍| 亚洲精品免费一二三区| 国产精品久久二区二区| 国产精品色呦呦| 一色屋精品亚洲香蕉网站| 亚洲特黄一级片| 一区二区三区日韩精品| 亚洲激情六月丁香| 亚洲精品第1页| 亚洲制服丝袜av| 亚洲小少妇裸体bbw| 亚洲图片欧美色图| 亚洲va国产天堂va久久en| 亚洲综合自拍偷拍| 一区二区三区欧美视频| 一区二区三区在线视频免费观看 | 精品1区2区3区| 欧美日韩一级片网站| 欧美蜜桃一区二区三区 | 亚洲女人****多毛耸耸8| 亚洲男人的天堂一区二区| 亚洲黄一区二区三区| 午夜精品免费在线观看| 免费高清在线一区|