Vue实现城市查询逻辑

前言

其实这个和之前的类似通讯录的是同一个页面,但是我觉得他们两个功能不同,所以分开来说了。

布局什么的就不说,模板部分贴个图出来:

我是模板

现在正式步入逻辑部分:
1.首先要把input框里的输入的搜索词和数据做一个双向绑定
这里用到的是v-model,绑定一个keyword,在data部分创建一个keyword变量,默认为空。
这样这样

2.search这个组件还要接收一下City组件传过来的数据,也就是所有城市列表的那个数据。
City组件传递数据

接收一下数据

3.然后再新建一个空数组list,它的作用是用来存放匹配的搜索结果。
4.写一个侦听器watch。监听keyword的改变。keyword对应的就是输入框的值。
watch侦听器里的逻辑

在这里做一个节流函数,提高代码的执行效率,因为这段的操作还是比较多的。去data处定义一个timer:null
回到watch,让主要操作在timer这个定时器里延时100毫秒执行,然后在上面写一个判断。这里的逻辑是,当keyword发生改变的时候,清除掉之前的逻辑,然后延时100毫秒执行新的逻辑操作。
在定时器里,我们写一个这样的操作。
先定义一个result空数组,然后循环一下cities里的内容,
然后在里面再做一遍 遍历,也就是先循环cities这个对象,然后将它里面的ABCD键值对,也就是那个数组再拿出来遍历一次,这个时候遍历的是这部分。
我是cities数据结构

在第二层遍历里,做一个这样的代码编写:
匹配操作

如果value中的spellname中能搜索到关键词,就将它添加到result之中。
循环完之后,要记得将result赋给this.list,用来存放结果。
然后再去模板处将list的内容循环出来
修改模板

优化1:如果没有匹配结果怎么办?

写上无匹配结果的dom

紧接着城市的li,写一个新的li,是用来显示无匹配结果的,
但是这个dom不是一直都存在的,用v-show来控制它的显示,仅仅当this.list有值,也就是:
无数据的逻辑判断

优化2:输入框置为'',搜索结果匹配所有怎么解决?

这个是当我们搜索框清空的时候,所有的结果都匹配上,然后出现了所有的城市列表。
对于这个我们在watch中加一个判断就行了。

清空判断

keyword没有值的时候,将this.list也置空,然后return出去,不执行下面的操作了。
为什么要置空list呢?因为搜索结果列表里的值是根据list来循环的。
别忘了做这个
没有输入时,整个搜索结果列表的dom都不显示

别忘了用BScroll做一下搜索列表的滚动操作。

用BScroll来做滚动

对于不清楚为啥一下要用watch,一下又是computed的时候,可以看这一篇计算属性、方法和侦听器

其实我开始思考想的是为啥不写在updated这个钩子函数里,不是说发生改变就会执行这个钩子函数吗?
后来在网上搜了一下

什么时候进updated方法?

只有事先设置好的data变量改变并且要在页面重新渲染{{}}完成之后,
才会进到这个方法,光改变data但不渲染页面是不会进来的

对于keyword,只是改变输入框的字,并未进行dom的重新渲染,所以应该不会进入updated钩子中,也就不能用这个。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,393评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,790评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,391评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,703评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,613评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,003评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,507评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,158评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,300评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,256评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,274评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,984评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,569评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,662评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,899评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,268评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,840评论 2 339

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,259评论 25 707
  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,043评论 0 29
  • 如果有一天你见到我 踩着晨曦步履匆匆 头发微乱不修边幅 在人头攒动的集市上熟练挑选老练的付钱 请不要惊讶于那样的我...
    胡美云阅读 314评论 1 0
  • 一直以为课需要精心地设计,按照自己的思路和预设,怎样开头,怎样结束,煞费苦心,愁坏了老师。有时候,自己的设计还就是...
    红儿_cd3a阅读 159评论 0 0
  • 一、抓关键词,仔细分析命题者的思想倾向和感情倾向。 命题者在命制试题时,往往将自己对材料的理解认识、感情倾向融合在...
    随遇而安小南北麻麻阅读 341评论 0 0