当前位置: 移动技术网 > IT编程>开发语言>JavaScript > JS实现移动端按首字母检索城市列表附源码下载

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

2017年12月12日  | 移动技术网IT编程  | 我要评论

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

 查看演示 下载源码 准备

    

准备

首先我们需要用到全国的城市数据,这些城市数据来源于网络,我已经将数据格式化成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实现移动端按首字母检索城市列表,希望对大家有所帮助

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网