欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JS实现移动端按首字母检索城市列表附源码下载

程序员文章站 2022-05-26 09:12:18
我们常见的手机通讯录或微信通讯录,联系人信息是按字母顺序排列的列表,通过点击右侧的字母,会迅速定位检索到首字母对应的联系人。那么我今天给大家介绍的是按首字母快速定位到城市列...

我们常见的手机通讯录或微信通讯录,联系人信息是按字母顺序排列的列表,通过点击右侧的字母,会迅速定位检索到首字母对应的联系人。那么我今天给大家介绍的是按首字母快速定位到城市列表,效果和通讯录一样的。

JS实现移动端按首字母检索城市列表附源码下载 查看演示 下载源码 准备

    

准备

首先我们需要用到全国的城市数据,这些城市数据来源于网络,我已经将数据格式化成json形式了,大家可以直接拿去用。

我们还需要用到一个叫better-scroll的滚动插件,它能帮我们将超长的页面原生的滚动条处理掉,优化滚动效果。

接着我们准备html结构。

<div class="city"> 
 <div class="city-wrapper city-wrapper-hook"> 
 <div class="scroller-hook"> 
 <div class="cities cities-hook"></div> 
 </div> 
 <div class="shortcut shortcut-hook"></div> 
 </div> 
</div> 

.cities是用来装载城市数据列表的;.shortcut是用来装载首字母列表的,需要使用css将其定位在右边侧。

javascript

写js代码之前,先将城市数据city.js和better-scroll加载进来。

<script src="js/bscroll.min.js"> </script> 
<script src="js/city.js"> </script>

开始写js,先定义要用到的变量:

var citywrapper = document.queryselector('.city-wrapper-hook'); 
var cityscroller = document.queryselector('.scroller-hook'); 
var cities = document.queryselector('.cities-hook'); 
var shortcut = document.queryselector('.shortcut-hook'); 
var scroll; 
var shortcutlist = []; 
var anchormap = {};

函数initcities()循环遍历city.js中的城市数据,提取其中的城市名称、首字母和id信息,一次性加入到数据列表中。接着调用bscroll插件方法。

function initcities() { 
 var y = 0; 
 var titleheight = 28; 
 var itemheight = 44; 
 var lists = ''; 
 var en = '<ul>'; 
 citydata.foreach(function (group) { 
 var name = group.name; 
 lists += '<div class="title">'+name+'</div>'; 
 lists += '<ul>'; 
 group.cities.foreach(function(g) { 
 lists += '<li class="item" data-name="'+ g.name +'" data-id="'+ g.cityid +'"><span class="border-1px name">'+ g.name +'</span></li>'; 
 }); 
 lists += '</ul>'; 
 var name = group.name.substr(0, 1); 
 en += '<li data-anchor="'+name+'" class="item">'+name+'</li>'; 
 var len = group.cities.length; 
 anchormap[name] = y; 
 y -= titleheight + len * itemheight; 
 }); 
 en += '</ul>'; 
 cities.innerhtml = lists; 
 shortcut.innerhtml = en; 
 shortcut.style.top = (citywrapper.clientheight - shortcut.clientheight) / 2 + 'px'; 
 scroll = new window.bscroll(citywrapper, { 
 probetype: 3 //1 会截流,只有在滚动结束的时候派发一个 scroll 事件。2在手指 move 的时候也会实时派发 scroll 事件,不会截流。 3除了手指 move 的时候派发scroll事件,在 swipe(手指迅速滑动一小段距离)的情况下,列表会有一个长距离的滚动动画,这个滚动的动画过程中也会实时派发滚动事件 
 }); 
 scroll.scrollto(0, 0); 
}

然后函数bindevent()绑定事件,监听右侧首字母的touchstart和touchmove事件。

function bindevent() { 
 var touch = {}; 
 var firsttouch; 
 shortcut.addeventlistener('touchstart', function (e) { 
 var anchor = e.target.getattribute('data-anchor'); 
 firsttouch = e.touches[0]; 
 touch.y1 = firsttouch.pagey; 
 touch.anchor = anchor; 
 scrollto(anchor); 
 }); 
 shortcut.addeventlistener('touchmove', function (e) { 
 firsttouch = e.touches[0]; 
 touch.y2 = firsttouch.pagey; 
 var anchorheight = 16; 
 var delta = (touch.y2 - touch.y1) / anchorheight | 0; 
 var anchor = shortcutlist[shortcutlist.indexof(touch.anchor) + delta]; 
 scrollto(anchor); 
 e.preventdefault(); 
 e.stoppropagation(); 
 }); 
 function scrollto(anchor) { 
 var maxscrolly = citywrapper.clientheight - cityscroller.clientheight; 
 var y = math.min(0, math.max(maxscrolly, anchormap[anchor])); 
 if (typeof y !== 'undefined') { 
 scroll.scrollto(0, y); 
 } 
 } 
}

最后调用执行两个函数。

initcities(); 
bindevent();

现在使用手机或平板访问就可以看到效果了,如果你要实现的是通讯录效果,可以将联系人数据信息格式化成city.js中对应的json即可。

以上所述是小编给大家介绍的js实现移动端按首字母检索城市列表,希望对大家有所帮助