html城市手机搜索,原生js实现html手机端城市列表索引选择城市

本文实例为大家分享了js实现手机端城市列表索引选择城市的具体代码,供大家参考,具体内容如下

html部分:

定位城市
上海市

css部分:

*{

margin: 0;

padding: 0;

list-style: none;

}

html{

font-size: 12px;

}

body {

background-color: #f5f5f5;

font-family: 'PingFang SC Regular', 'PingFang SC';

width: 100%;

height: 100%;

min-width: 320px;

max-width: 480px;

position: relative;

}

.cityPage {

width: 100%;

height: 100%;

/* border: 1px solid black; */

position: relative;

top: 0;

display: flex;

flex-direction: column;

/* justify-content: center; */

}

.cityContent {

width: 100%;

height: 140px;

/* border: 1px solid black; */

background: #f7f7f9;

position: fixed;

z-index: 9999;

top: 0;

}

.inputBox input {

width: 90%;

height: 30px;

border: 1px solid rgb(215, 215, 215);

outline: none;

background: #fff;

margin-left: 4%;

border-radius: 4px;

padding-left: 4px;

color: #9e9e9e;

font-size: 14px;

margin-bottom: 16px;

margin-top: 14px;

}

.localCity {

color: #333;

font-size: 13px;

font-weight: bold;

margin-left: 4.5%;

margin-bottom: 16px;

}

.cityname {

font-size: 13px;

margin-left: 4.5%;

margin-bottom: 16px;

}

#list {

font-size: 13px;

position: fixed;

height: 100%;

top: 140px;

width: 100%;

overflow: scroll;

font-size: 15px;

/* margin-bottom: 140px; */

/* bottom: 200px; */

}

#list>section {

overflow-y: auto;

height: 100%;

margin-bottom: 140px;

}

#list>section>dl>dt {

background: #f7f7f9;

color: #999;

height: 40px;

line-height: 40px;

padding-left: 15px;

}

#list>section>dl>dd {

color: #333;

line-height: 40px;

padding-left: 15px;

position: relative;

background-color: #fff;

}

#list>section>dl>dd:after {

content: '';

position: absolute;

left: 0;

bottom: 1px;

width: 100%;

height: 1px;

background-color: #c8c7cc;

transform: scaleY(.5);

-webkit-transform: scaleY(.5);

}

#list>section>dl>dd:last-of-type:after {

display: none;

}

#navBar {

position: fixed;

width: 26px;

height: 50%;

right: 0;

z-index: 30;

top: 50%;

display: flex;

flex-direction: column;

margin-top: -25%;

/* text-align: center; */

}

#navBar.active {

background: rgba(211, 211, 211, .6);

}

#navBar>div {

text-align: center;

display: block;

text-decoration: none;

/* height: 4.166%;

line-height: 100%; */

color: #333;

font-size: 13px;

flex: 1;

}

.letterBox{

width: 40px;

height: 40px;

background:#9f9f9f;

opacity: .5;

position: fixed;

top: 50%;

left: 50%;

margin-top: -25px;

margin-left: -25px;

text-align: center;

line-height: 40px;

color: #fff;

display: none;

}

js部分:

$(function () {

initCities(cityData);

clickAction()

//输入城市查询

var key = false;

$('#findcityInp').on('compositionstart', function () {

key = true;

console.log('不搜索')

});

$('#findcityInp').on('compositionend', function (e) {

var keyWord = $.trim(e.target.value);

if(keyWord.length>0){

var result = findCity(keyWord, cityData);

initCities(result);

bindEvent();

}else{

initCities(cityData);

bindEvent();

}

});

$('#findcityInp').on('change', function (e) {

var keyWord = $.trim(e.target.value);

console.log(keyWord)

var result = findCity(keyWord, cityData);

// console.log(result)

initCities(result)

});

//城市查询

function findCity(keyWord, data) {

if (!(data instanceof Array)) return;

var reg = new RegExp(keyWord);

var arr = [];

var obj ={

name:'',

cities:[]

}

if(keyWord.length>0 && checkCh(keyWord)==false){

data.forEach((item, index) => {

item.cities.forEach((childItem, childIndex) => {

if (childItem.tags.match(reg)) {

obj.name = childItem.tags[0];

obj.cities.push(childItem)

arr=[obj]

}

})

})

}else if(keyWord.length ==1 && checkCh(keyWord)==true){

data.forEach((item,index)=>{

if(item.name == keyWord){

// console.log(item)

arr.push(item)

}

})

}

else{

arr = data

}

return arr;

}

function checkCh(str){

var RegExp = /^[a-zA-Z]{1}$/;

return RegExp.test(str);

}

//点击右边描点

function toTarget(tag){

var text = $(tag).text();

location.href = "#"+text;

$('.letterBox').html(text);

$('.letterBox').show()

setTimeout(function(){

$('.letterBox').hide()

},1000)

}

//初始化城市列表

function initCities(cityData) {

var g = "";

$('section').html('');

$('nav').html('')

cityData.forEach((item, index) => {

g += "

" + item.name + "

item.cities.forEach((citiesItem, citiesIndex) => {

g += "

" + citiesItem.name + ""

})

g += "

"

})

$('section').append(g);

var g = $('nav').height() / 26;

var f = '';

cityData.forEach((item, index) => {

// f += '' + item.name + ""

f+=`

${item.name}
`

})

$('nav').append(f);

}

//点击城市列表某城市

function clickAction(){

$('.list').click(function (e) {

console.log(e.target.getAttribute('data-name'))

})

}

7e138f34225914a039bb432928cc7f62.gif

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

展开阅读全文

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/558447.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

html 图片使用scale,缩放:scale() - CSS3 | 绿叶学习网

在CSS3中,我们可以使用transform属性的scale()方法来实现元素的缩放效果。缩放,指的是“缩小”和“放大”的意思。语法:transform: scaleX(x); /*沿X轴方向缩放*/transform: scaleY(y); /*沿Y轴方向缩放*/transform: scale(x, y); /*沿X轴和Y…

dbeaver无法修改表数据_隐藏彩蛋:你知道python有一个内置的数据库吗?

全文共2520字,预计学习时长7分钟如果你是软件开发人员,相信你一定知道甚至曾经使用过一个非常轻量级的数据库——SQLite。它几乎拥有作为一个关系数据库所需的所有功能,而且这些有功能都保存在一个文件中。下面是一些官方网站显示可以使用SQL…

批量删除HTML链接软件,3种方法教你一次性删除word文档中的所有超链接

您可能感兴趣的话题:Word核心提示:在编辑文档时,可能会在文档以外复制一些内容进来,但是总会有一些烦人的链接很难去掉。或是WORD 从网上下了一些资料,存到 word 里面,里面很多文字和图片都带有超链接。下面小编就为大家介绍3种方…

一文道破Java中的深拷贝,浅拷贝,零拷贝

前言 在Java编写代码中,对象的拷贝是一个常见的操作。根据拷贝的层次和方式不同,可以分为深拷贝、浅拷贝和零拷贝。本篇文章我们将详细介绍这三种拷贝方式的概念、实现方法以及使用场景,方便大佬学习及面试。 深拷贝 深拷贝是一种创建对象副…

关键词热度分析工具_谷歌SEO推广排名的关键要素(一)利用谷歌关键词分析工具分析关键词...

大家好,我是谷歌鸿飞,到今年算起,从业谷歌SEO,已经十一个年头了。服务过的外贸企业也有几百家,接触和操作过外贸产品也有上千种。这么多的企业,这么多的产品,思绪万千,不知如何下笔。…

计算机桌面设置定时,如何设置可以每月自动变化的日历桌面?

设置步骤:1、显示电脑桌面(即把所有窗口都最小化);2、Windows Xp和Windows 2000设置有些不同:(windows vista好像不能设置活动桌面)Windows xp:在电脑桌面点击鼠标右键,出现菜单,选择“属性”,然…

系统辨识理论及应用_控制理论学习书单推荐(值得一读)

经 System control 授权,基于控制理论学习书单整理改编。提起系统与控制领域的学习,经常被谈论到的就是,对于刚接触这个领域的初学者总会在各种控制理论中迷茫,有的甚至直接劝退。面对众多理论,完全无从下手。下面就简…

重庆电子工程学院计算机专业,重庆计算机电子工程职业学院2020年招生录取分数线...

重庆计算机电子工程职业学院2020年录取分数线暂未公布,预计在2020年6月份公布。以往数据表明高职院校的录取分数线和当年的高考题目难易程度有关,考生可参考重庆计算机电子工程职业学院历年来院校录取分数线情况。重庆计算机电子工程职业学院录取分数线招…

上海交通大学计算机应用基础答案,西安交通大学17年3月课程考试《计算机应用基础》作业考核试题答案...

http://www.mouxue.com/forum.php? ... p;page1#pid1402268一、单选题(共 30 道试题,共 60 分。)V 1. 在Wor中,要选定全文,可用的快捷键为()。. trlS. trlV. trl. trl标准答案:2. Winows XP 任务栏不能设置为()。. 自动隐藏. 时…

正则只能小于0负数_2019–2020学年七年级数学期末考试考点之正数与负数考点详解...

七年级数学期末考试第一讲之正数与负数考点详解嗨,大家好,这里是摆渡学涯。马上我们就要迎来期末考试了,你们有没有开始复习呢?这次课程咱们来为大家讲一下数的考点,教你轻松学数学。数的概念数从是否为正负数的角度来…

HTML可以替代CSS的所有功能,CSS-用Divs替换HTML表

CSS-用Divs替换HTML表好吧,我试图接受这样的想法,即不应使用html表,而应使用div。 但是,我经常有类似于以下内容的代码First Name:Last Name:Address:NYCAUSACAN我希望标签对齐并且我希望控件对齐。 不使用表格怎么办?…

controller接收json数据_SpringMVC实现多种数据类型绑定

点击上方“放学等我”,选择“置顶公众号”精品文章,第一时间送达绑定基本数据类型Java基本数据类型int的默认值是0,在使用int进行url传递参数时,参数key是必须写的,其值也只能是int类型的,否则将会报错。 比…

初中学历在辽宁学计算机,在辽宁省实验中学学习是怎样一番体验?

本人姓名:韩杨泰衍。辽宁省实验中学2012届毕业生,2012年高考考入清华大学。第一次在知乎上写回答,有言语不当之处还请各位看官见谅。体验之一:学习上不断积累与释放的自卑感,伴随着不断获得和失去的荣誉。我2009年中考…

宝塔设置thinkphp的伪静态_宝塔面板与WDCP狭路相逢,谁才是国产之光?

我本来想给大家写一篇工具类的杂谈,思来想去又想到了可视化面板,就目前国产面板而言,WDCP、宝塔面板、AMH等,说是群雄逐鹿一点都不为过,AMH4.2之后,可以说是走了相当一部分人,暗示收费版本&…

计算机桌面打标签,在电脑桌面上添加便签的方法步骤详解(2)

电脑的桌面便签软件推荐1、CintaNotes电脑的桌面便签软件推荐图1CintaNotes是一款非常轻巧实用的笔记软件,可看作EverNote轻量级替代品。CintaNotes只需1个exe,体积仅1MB,却拥有EverNote易于收集、实时搜索、条状排列、tag分类的优点,更有EverNote 所不具备的中文搜索、纯文本更…

windows。forms.timer设置第一次不等待_适用于初学者的中线交易策略——金叉的三种设置条件...

本文将介绍了使用移动平均线最重要的方法之一——金叉。我们将描述该信号的产生条件,然后深入探讨一下三个交易案例。什么是金叉?当短期移动平均线与长期移动平均线相交时,黄叉就会产生。听起来确实很简单。然而,关键是构成交叉的移动平均线…

html如何做卷展菜单,3DMax“对象属性”卷展栏如何操作?有啥秘诀呢?

“动画”菜单 “骨骼工具”“骨骼工具”浮动框 “对象属性”卷展栏。使用骨骼“对象属性”卷展栏上的控件可以将其他对象转变为骨骼。这些控件还可以控制骨骼的刚性及对齐方式。注意使用“重置缩放”选项可以重置骨骼的缩放。1、启用/禁用骨骼启用此选项后,选定骨骼…

python多线程写同一个文件_Python多线程快速写入文件,python,飞速

Python多线程快速写入文件,python,飞速 发表时间:2020-07-10 乱序多线程写入 举个最简单的例子,只要求快速写入即可,对顺序无要求时: import threading def write_string(string, path"test.csv"): with open(path, a) …

2021山东科技大学计算机学院,2021年3月山东科技大学计算机等级考试报名工作通知...

【导语】2021年3月山东科技大学计算机等级考试报名工作通知已公布,为了方便广大考生的查阅,下面无忧考网为您详细介绍一下本次计算机等级考试报名的具体事宜,希望广大考生及时关注,如有相关疑问,敬请关注无忧考网为您实…

怎么查看电脑有没有python_python人工智能爬虫系列:怎么查看python版本_电脑计算机编程入门教程自学...

本文由简码编程原创,保留所有版权,转载请注明出处。 本python人工智能爬虫系列教程基于Python3.0版本, 将python结合windows桌面开发工具aardio一起做可视化的开发, 用python做逻辑处理,用aardio做窗口界面, 不用再看着黑黑的python命令行窗口, 有window…