当前位置: 移动技术网 > IT编程>脚本编程>vue.js > Vue实现百度下拉提示搜索功能

Vue实现百度下拉提示搜索功能

2017年12月12日  | 移动技术网IT编程  | 我要评论
一、前期准备 网上大神已经做过这个功能 这自己仅实现搜索功能 为了使用百度实现搜索功能,首先搞清楚下拉数据和搜索功能的数据接口 01、提示数据获取地址 打开

一、前期准备

网上大神已经做过这个功能 这自己仅实现搜索功能
为了使用百度实现搜索功能,首先搞清楚下拉数据和搜索功能的数据接口

01、提示数据获取地址

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


提示数据获取地址.png

然后简化一下:

复制代码 代码如下:
https://sp0.baidu.com/5a1fazu8aa54nxgko9wtanf6hhy/su?wd=a&cb=jquery110208352732182923484_1497924041050&_=1497924041057#

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


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

02:搜索功能实现地址

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


搜索地址.png

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


简化地址.png

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


测试.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代码

<div class="container search-container" id="app">
  <h1 class="title" >baidu-search</h1>
  <input type="text" class="form-control" placeholder="请输入想要搜索关键字" v-model="keyword" @keyup="get($event)" @keydown.down.prevent="selectdown"
  @keydown.up.prevent="selectup">
  <ul>
    <li class="text-center" v-for="(value,index) in mydata"><span class="text-success textprimary" :class="{gray:index==now}">{{value}}</span></li>
  </ul>
  <p ><h2 v-show="mydata.length==0" class="text-warning text-center">(*^__^*)暂时没有数据</h2></p>
</div>

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


提示数据.png

然后selectdown和selectup实现上下选中数据,当按下回车键时,实现搜索
完整代码:

三、实现效果


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

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网