欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2020年06月18日 17:20:02   作者:蝙蝠俠X3  
這篇文章主要為大家詳細(xì)介紹了原生JS實(shí)現(xiàn)微信通訊錄,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

最近工作當(dāng)中再一次遇到要實(shí)現(xiàn)一個(gè)車輛列表,要求能夠像微信通訊錄一樣,實(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)諒。

原本微信通訊錄效果:

本案例效果圖:

實(shí)際工作中可以實(shí)現(xiàn)類似于城市列表,產(chǎ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="./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)并沒(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í)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 從階乘函數(shù)對(duì)比Javascript和C#的異同

    從階乘函數(shù)對(duì)比Javascript和C#的異同

    今天學(xué)習(xí)Javascript函數(shù),發(fā)現(xiàn)這完全是一個(gè)神奇的東西。跟我們平常所見(jiàn)強(qiáng)類型語(yǔ)言中的函數(shù)有好多不同。下面我們就從C#和JavaScript的兩個(gè)計(jì)算階乘的函數(shù)中比較兩者的異同
    2012-05-05
  • js常用節(jié)點(diǎn)操作實(shí)例總結(jié)

    js常用節(jié)點(diǎn)操作實(shí)例總結(jié)

    這篇文章主要介紹了js常用節(jié)點(diǎn)操作,結(jié)合實(shí)例形式總結(jié)分析了JavaScript針對(duì)dom節(jié)點(diǎn)的遍歷、查找、創(chuàng)建、刪除、克隆等相關(guān)實(shí)現(xiàn)技巧與注意事項(xiàng),需要的朋友可以參考下
    2023-04-04
  • js實(shí)現(xiàn)延遲加載的幾種方法詳解

    js實(shí)現(xiàn)延遲加載的幾種方法詳解

    今天小編就為大家分享一篇關(guān)于js實(shí)現(xiàn)延遲加載的幾種方法詳解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-01-01
  • 我所理解的JavaScript中的this指向

    我所理解的JavaScript中的this指向

    這篇文章主要介紹了JavaScript中this指向的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)JavaScript,感興趣的朋友可以了解下
    2020-09-09
  • JavaScript實(shí)現(xiàn)的雙向跨域插件分享

    JavaScript實(shí)現(xiàn)的雙向跨域插件分享

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)的雙向跨域插件分享,本文實(shí)現(xiàn)把整個(gè)跨域過(guò)程抽象出來(lái),封裝成一個(gè)JavaScript插件,需要的朋友可以參考下
    2015-01-01
  • layui 對(duì)table中的數(shù)據(jù)進(jìn)行轉(zhuǎn)義的實(shí)例

    layui 對(duì)table中的數(shù)據(jù)進(jìn)行轉(zhuǎn)義的實(shí)例

    今天小編就為大家分享一篇layui 對(duì)table中的數(shù)據(jù)進(jìn)行轉(zhuǎn)義的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-09-09
  • JavaScript中Object和Function的關(guān)系小結(jié)

    JavaScript中Object和Function的關(guān)系小結(jié)

    JavaScript 中 Object 和 Function 的關(guān)系是微妙的,他們互為對(duì)方的一個(gè)實(shí)例。
    2009-09-09
  • JS實(shí)現(xiàn)玩轉(zhuǎn)風(fēng)車

    JS實(shí)現(xiàn)玩轉(zhuǎn)風(fēng)車

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)玩轉(zhuǎn)風(fēng)車,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • JavaScript數(shù)據(jù)結(jié)構(gòu)之鏈表各種操作詳解

    JavaScript數(shù)據(jù)結(jié)構(gòu)之鏈表各種操作詳解

    數(shù)據(jù)結(jié)構(gòu)是一種有效處理大量數(shù)據(jù)的手段,了解它的結(jié)構(gòu)和組成為我們提供了更有效的工具來(lái)設(shè)計(jì)與某些問(wèn)題相關(guān)的產(chǎn)品。這次我們將進(jìn)行鏈表介紹,回顧它的特點(diǎn)和用途
    2022-10-10
  • js 上傳文件預(yù)覽的簡(jiǎn)單實(shí)例

    js 上傳文件預(yù)覽的簡(jiǎn)單實(shí)例

    下面小編就為大家?guī)?lái)一篇js 上傳文件預(yù)覽的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-08-08

最新評(píng)論