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

本案例效果圖:

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

代碼展示
Dom
Dom結(jié)構(gòu)僅供參考,實(shí)際情況看自己需求,比如我現(xiàn)在工作當(dāng)中使用的React框架,這個(gè)靜態(tài)的dom結(jié)構(gòu)肯定不適用,不過萬變不離其宗,原理都是通過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="./js/flexible_css.js"></script> <script src="./js/flexible.js"></script> <link rel="stylesheet" href="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)并沒有用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í)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
js控制滾動(dòng)條緩慢滾動(dòng)到頂部實(shí)現(xiàn)代碼
滾動(dòng)條緩慢滾動(dòng)到頂部這樣的效果想必大家在瀏覽網(wǎng)頁的時(shí)候都有見過吧,本文使用js實(shí)現(xiàn)下,感興趣的你可不要錯(cuò)過了哈,希望可以幫助到你2013-03-03
JavaScript彈出新窗口后向父窗口輸出內(nèi)容的方法
這篇文章主要介紹了JavaScript彈出新窗口后向父窗口輸出內(nèi)容的方法,涉及javascript窗口操作的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-04-04
JavaScript進(jìn)制轉(zhuǎn)換實(shí)現(xiàn)方法解析
這篇文章主要介紹了JavaScript進(jìn)制轉(zhuǎn)換實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了JavaScript進(jìn)制轉(zhuǎn)換中十進(jìn)制與其他進(jìn)制轉(zhuǎn)換、以及隨機(jī)顏色生成相關(guān)操作技巧,需要的朋友可以參考下2020-01-01
JS+DIV+CSS實(shí)現(xiàn)仿表單下拉列表效果
這篇文章主要介紹了JS+DIV+CSS實(shí)現(xiàn)仿表單下拉列表效果,涉及javascript鼠標(biāo)事件及頁面元素的動(dòng)態(tài)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08
基于javascript實(shí)現(xiàn)簡(jiǎn)單的抽獎(jiǎng)系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了基于javascript實(shí)現(xiàn)簡(jiǎn)單的抽獎(jiǎng)系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-03-03
JavaScript字符串對(duì)象(string)基本用法示例
這篇文章主要介紹了JavaScript字符串對(duì)象(string)基本用法,結(jié)合實(shí)例形式分析了js字符串的添加、計(jì)算、獲取、替換等操作實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-01-01
詳解使用Nuxt.js快速搭建服務(wù)端渲染(SSR)應(yīng)用
這篇文章主要介紹了詳解使用Nuxt.js快速搭建服務(wù)端渲染(SSR)應(yīng)用,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-03-03

