快来收藏吧!在Vue 中使用http仿百度实现搜索功能

原创出处:http://mp.toutiao.com/preview_article/?pgc_id=6530491969771143687

老规矩,先上图1-1-1,一切看图说话:

image

图1-1-1

用户在输入框中输入关键字,系统会立刻查询出你想要的内容,通过上下键选择,按enter 键即可进去百度页面里,这看起来是不是很神奇,想不到自己也可以写个百度搜索出来,是不是很牛逼,是不是很6呢。是的话,快点赞转载,这是您对我最大的鼓励。。。废话不多说,下面看看实现方式。

此功能的技术要点主要是利用了http 请求交互以及vue中指令,事件的运用。对的,程序员学习最快的方式莫过于多写代码多练习,将理论与实际项目相结合这才是最牛逼之处,看过我文章的人一定会越来越牛逼的。

一、准备工作

1. 新建 searchWithKey.html 文件,引入vue 相关的文件,如Vue.js、vue-resource.js,不清楚使用的同学可以查看之前写的文章《今天你看了吗?Vue框架之数据交互http请求》,先写下基本的html元素标签,如代码图1-1-2:

image

图1-1-2

2. 编写html 布局代码,我们需要接收用户的输入信息,所以只要使用<input> 标签,我们需要使用列表来展示搜索的结果,所以使用<ul> 即可,如图1-1-3

image

图1-1-3

注:

(1) v-model="searchKey" 双向数据绑定,当用户输入内容后,通过“searchKey” 可以将值传给Vue js中使用。

(2) @keydown.enter="enterToSearchResult()" 键盘Enter 键事件, @keydown.enter 与v-on:keydown.enter 一样,前者是缩写; @keyup.up.prevent="changeUpItem()"键盘向上方向键, prevent 属性是防止光标跳动; 括号内的是在Vue 中声明的方法。@keyup.down="changeDownItem()" 键盘向下方向键。

(3) v-for="(item,index) in myResult" 这种循环数组的写法还记得吗?括号内的两个参数,前者是数组中的对象,后者表示在数组中的位置。

(4) :class="{gray:index == nowIndex}" 这是什么意思?是不是有点看不懂呢。 :class 也可以写成v-bind:class, 其实是为了简单而缩写成这样子的,意思是 只要 index 与 nowIndex 相等时样式gray 才会起作用,否则无效。

3. 编写html 样式,在<head> 与 </head> 之间编写以下代码用于美化界面,如下图1-1-4

image

图1-1-4

二、编写核心代码Vue.js

  1. 声明所需要的变量及方法,如图1-1-5:
image

图1-1-5

嗯,都不要急,代码是一点一点写出来的,重要的是思路。

2. 写上核心代码,接收用户输入,开始搜索内容,因此我们可以通过Vue 中watch 来实现,watch 意思是观察某个方法或某个变量值发生变化。如下代码图1-1-6:

image

图1-1-6

从这里开始,是不是有点乱呢,先不要急,继续看下去。你们肯定是有疑问是吧,为什么这里要判断是否 等 -1 呢,因为呢,这是为避免重复调用并请求搜索新内容。当用户利用方向键进行上下内容切换时,this.nowindex 的值是会发生变化的。

image

图1-1-7 searchContentByJsonp 方法的实现

changeDownItem 和 changeUpItem 方法的实现,即键盘向上及向下事件,如下图1-1-8:

image

图1-1-8

注: 上面的有没有不理解的地方呢,比较复杂的就是逻辑,主要是判断当前下标nowIndex 的值。

当用户选中系统检索出来的内容后,按下enter 便会打开新的网页,如下图1-1-9:

image

图1-1-9

以上就是基本的核心代码,下面写上完整代码。

三、完整代码如下:

<html>

<head>

<title> 实现仿百度搜索功能 </title>

<meta charset="utf-8"/>

<script src="lib/vue/vue.js" type="text/javascript" charset="utf-8"> </script>

<script src="lib/vue/vue-resource.js" type="text/javascript" charset="utf-8"></script>

<script type="text/javascript">

window.onload = function (){

new Vue({

el:"#box",

data:{

searchKey:"",

myResult:[],

nowIndex:-1

},

watch:{ // 观察 searchKey是否发生改变

searchKey: function(){

if( this.nowIndex ==-1){

this.searchContentByJsonp();

}

}

}

,

// 声明请求方法

methods:{

enterToSearchResult: function(){

if(this.nowIndex !=-1 && this.searchKey.length >0){

window.open('https://www.baidu.com/s?wd='+this.searchKey);

}

},

searchContentByJsonp: function(){

var apiUrl = "https://sug.so.360.cn/suggest?encodein=utf-8&encodeout=utf-8&format=json&fields=word&word="+this.searchKey;

this.$http.jsonp(apiUrl).then(function(successData){

this.myResult = JSON.parse(successData.bodyText).result;

}, function(errorData){

console.log("===============faile================="+errorData)

})

},

changeDownItem: function (){

console.log("===========changeDownItem==========");

this.nowIndex++;

if( this.nowIndex ==this.myResult.length){

this.nowIndex = 0;

}

this.searchKey = this.myResult[this.nowIndex].word;

},

changeUpItem: function (){

console.log("===========changeUpItem==========");

this.nowIndex--;

if(this.nowIndex == -1){

this.nowIndex=this.myResult.length-1;

}

this.searchKey = this.myResult[this.nowIndex].word;

}

}

})

}

</head>

<body>

<div id="box">

<input type="text" value placeholder="请输入要搜索的内容" v-model="searchKey" @keydown.enter="enterToSearchResult()" @keyup.up.prevent="changeUpItem()" @keyup.down="changeDownItem()"/>

<ul>

<li v-for="(item,index) in myResult" :class="{gray:index == nowIndex}">

<span>{{item.word}}</span>

</li>

</ul>

<p v-show="myResult.length==0">暂无数据</p>

</div>

</body>

</html>

注: 这个代码真的好难看,可以这个编辑器就这样子。唉,我也是没办法的事,还请各位多多谅解。

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

推荐阅读更多精彩内容

  • 深入响应式 追踪变化: 把普通js对象传给Vue实例的data选项,Vue将使用Object.defineProp...
    冥冥2017阅读 4,860评论 6 16
  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,048评论 0 29
  • 因为每一年生日都过的不一样,所以每一年要记得我生日也很麻烦,庆幸的是,你们都记得! 今年或许是个不一样的生...
    Joanna叔阅读 235评论 0 0
  • 又到栀子花开人离别的季节,一句再见或许再也不见。 一年一次的毕业季还是来了。 我们的青春,快到终点。 想想当初的你...
    大仙席安Jaime阅读 348评论 0 1
  • 我是一个喜欢在深夜里胡思乱想的人,夜幕降临,我静静的躺在床上,望着漆黑的天花板,在夜深人静的晚上听着自己的...
    香雪紫荆山阅读 391评论 0 0