搜索引擎下拉html,Vue实现百度下拉提示搜索功能

一、前期准备

网上大神已经做过这个功能https://github.com/lavyun/vue-demo-search 这自己仅实现搜索功能

为了使用百度实现搜索功能,首先搞清楚下拉数据和搜索功能的数据接口

01、提示数据获取地址

打开百度官网打开开发者调试工具,选中network一项,然后我们在搜索框输入'a',将会network发送的请求,这个就是提示数据的数据获取地址

d0a297207289e9b2c97323d356365cf5.png

提示数据获取地址.png

然后简化一下:

复制代码 代码如下:

https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd=a&cb=jQuery110208352732182923484_1497924041050&_=1497924041057#

其中“wd=”后接搜索的关键字,“cb=”后接回调函数

a941f7186e6b8df6066ce44ca7f7a130.png

输入a时,请求的提示数据

02:搜索功能实现地址

在输入框中输入“a”之后,点击搜索按钮之后,地址栏中地址就是实现搜索功能的地址

10ef8199c76b46c4afe63c10c5510550.png

搜索地址.png

搜索地址简化前后对比,是不是看起来很舒服了O(∩_∩)O

b223712d4b31414692a6260a0f85ec6a.png

简化地址.png

我们使用简化之后的地址,搜索关键字“s‘'测试一下

746636373d19112d11046da484e7e662.png

测试.png

二、代码实现

js代码

new Vue({

el:'#app',

data:{

myData:[],

keyword:'',

now:-1

},

methods:{

get:function (event) {

if(event.keyCode==38||event.keyCode==40)return;

if(event.keyCode==13){

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

this.keyword=''

}

this.$http.jsonp('https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su',{

wd:this.keyword

},{

jsonp:'cb'

}).then(function (res) {

this.myData=res.data.s;

},function () {

});

},

selectDown:function () {

this.now++;

if(this.now==this.myData.length)this.now=-1;

this.keyword=this.myData[this.now];

},

selectUp:function () {

this.now--;

if(this.now==-2)this.now=this.myData.length-1;

this.keyword=this.myData[this.now];

}

}

})

html代码

baidu-search

@keydown.up.prevent="selectUp">

  • {{value}}

(*^__^*)暂时没有数据

get方法实现获取下拉数据和搜索功能,输入keyword之后,调用get方法使用jsonp获取提示数据,然后赋值给myData,然后使用v-for遍历提示数据

5dea87d2b14a492c218d76a575812026.png

提示数据.png

然后selectDown和selectUp实现上下选中数据,当按下回车键时,实现搜索

完整代码:https://github.com/yanqiangmiffy/baidu-search

三、实现效果

c4389299d35e5af470c02e29e461820a.gif

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

时间: 2017-06-20

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值