今天做到了一个联系人列表的需求, 要求和微信的一样! 写出来分享给大家, 使用了jq和doT模版引擎
首先对数据源进行数据排序
// 数据排序 function sortData(data) { var letterArr = []; for (var i = 0; i < data.length; i++) { for (var j = 0; j < data.length; j++) { if (data[i].flag < data[j].flag) { var temp = data[i]; data[i] = data[j]; data[j] = temp; } } } if (f_check_uppercase(data[0].flag)) { letterArr.push(data[0].flag) } else { letterArr.push('#') } for (var i = 0; i < data.length; i++) { if(f_check_uppercase(data[0].flag)) { data[0].flagLetter = data[0].flag } else { data[0].flagLetter = '#' } if (i>0) { if (data[i].flag !== data[i-1].flag) { if (f_check_uppercase(data[i].flag)) { data[i].flagLetter = data[i].flag; letterArr.push(data[i].flag) } else { data[i].flagLetter = '#'; letterArr.push('#') } } } }
// 侧边栏 var str = '' ; for (var i = 0; i < letterArr.length; i++) { str += '<a ontouchstart="anchorJump(this)" >'+ letterArr[i] +'</a>' } $('.slidePage div').html(str) $('.resultList').html(doT.template($('#listT').text())(data)) } // 判断是否是字母 function f_check_uppercase(obj) { if (/[A-Z]/.test(obj)) { return true; } return false; }
然后是跳转锚点
location.hash = '#id' 和a标签的作用相同, 跳转到指定锚点
// 跳转锚点 function anchorJump(n) { var text = $(n).text(); if (text.length < 2) { $('.letter').text(text) $('.letter').css({'opacity':' 1'}) location.hash = '#' + text } }
手指滑动, 页面跳转
// 手指滑动 function move() { // 阻止默认事件, 页面滑动 event.preventDefault(); anchorJump(document.elementFromPoint(event.changedTouches[0].clientX,event.changedTouches[0].clientY)) }
document.elementFromPoint(x,y) 获取指定坐标的顶层元素
最后滑动结束, 手指离开屏幕
// 滑动结束 function touchEnd() { var opcityNum = 1; setInterval(function () { opcityNum -= 0.1; if (opcityNum > 0) { $('.letter').css({'opacity': opcityNum}) } else { clearInterval(); } },50) }
点击每条数据
// 点击事件 function clickInfo(ele) { alert($(ele).find('.name').text()) }
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助~如果有疑问大家可以留言交流,谢谢大家对的支持!
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“JavaScript仿微信(电话)联系人列表滑动字母索引实例讲解(推荐)”评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新动态
2024年11月14日
2024年11月14日
- 黑鸭子2010-再度重相逢[首版][WAV+CUE]
- 【原神手游】5.2版本圣遗物优化详情
- 方季惟.1989-一生只爱一次【蓝与白】【WAV+CUE】
- 群星.1997-强力舞曲总动员【金点】【WAV+CUE】
- 盘尼西林.2024-岛与黎明【智慧大狗】【FLAC分轨】
- 刀郎《柔情经典》 2CD[WAV分轨][3.8G]
- 群星2024《民谣精选》原音母版1:1直刻[低速原抓WAV+CUE][1.1G]
- 经典《泰坦尼克号原声大碟》[WAV+DSF+FLAC多版][5.2G]
- 魔兽世界兽王猎输出宏代码是什么 兽王猎翻页输出宏命令代码分享
- 魔兽世界wlk野德一键输出宏是什么 wlk野德一键输出宏介绍
- wlk鸟德一键输出宏是什么 wlk鸟德一键输出宏介绍
- 《明末:渊虚之羽》外网新宣传:有勇气面对障碍吗?
- 视觉盛宴!V社公布《看火人》团队新作水面物理效果演示
- 张艺谋呼吁观众走进影院看电影:对解说短视频很无语
- 车载音乐最强享受 《车载极致女声精选》[WAV分轨][1G]