vue实现百度搜索功能

本文实例为大家分享了vue实现百度搜索功能的具体代码,供大家参考,具体内容如下

最终效果:

vue实现百度搜索功能

Baidusearch.vue所有代码:

<template>
 <div>
  <div class=\"container\" id=\"app\">
  <div class=\"page-header\">
   <h2 class=\" text-center text-primary\">百度搜索案例</h2>
  </div>
  <form action=\"\">
   <div class=\" form-group\">
   <input v-model=\"wd\" @keyup=\"keyup($event)\" @keydown=\"keydown($event)\" type=\"text\" class=\"form-control\" />
   <ul class=\"list-group\">
    <li class=\"list-group-item list-group-item-text\" v-for=\"(item,index) in arr\" :class=\"{\'list-group-item-info\':index==listIndex}\" @click=\"click($event)\">{{item}}</li>
   </ul>
   </div>
  </form>
  </div>
 </div>
</template>
 
<script>
 export default {
  name: \"Baidusearch\",
  data(){
   return{
   wd:\'\',//搜索的关键词
   arr:[],//用于储存关键词的搜索词条
   listIndex:-1//设置初始索引,数组从0开始,因此初始成-1
   }
  },
  methods:{
  //这个函数我们在input标签输入关键词的时候不断的给百度服务器发送请求获取搜索词条,并且不断的复制给data中的数组arr
  keyup(event){
   //如果我按的是上下键,那么就不发送请求了
   console.log(event);
   if(event.keyCode==38||event.keyCode==40||event.keyCode==13) return ;
   var url=\"https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su\"
   this.$http.jsonp(url,{
   params:{
    wd:this.wd
   },
   jsonp:\'cb\'
   }).then(res=>{
   console.log(res);
   this.arr=res.data.s;//把百度服务器返回的数据传给arr数组
   })
  },
  //监听鼠标的点击事件
  //如果鼠标点击某一行的文字,则点击事件中的event.explicitOriginalTarget.data代表关键词
  //如果点击某一行的空白处,则点击事件中的event.explicitOriginalTarget.innerText代表关键词
  //大家可以通过console.log(event)来查看关键词所在的位置
  click(event){
   console.log(event);
   if(event.explicitOriginalTarget.data!=undefined){
   this.wd=event.explicitOriginalTarget.data;
   window.open(\"https://www.baidu.com/s?wd=\"+this.wd);
   }else if(event.explicitOriginalTarget.innerText!=undefined){
   this.wd=event.explicitOriginalTarget.innerText;
   window.open(\"https://www.baidu.com/s?wd=\"+this.wd);
   }
  },
  //监听键盘的事件
  //如果按down,则增加当前listIndex+1,因此arr[this.listIndex]就能代表当前的词条
  //我们通过对listIndex的修改来得到当前词条在arr中的索引,然后就可以得到词条的具体信息,然后发送请求了
  keydown(event){
   console.log(event);
   //下键:40 上键:38
   if(event.keyCode==38){
   //按的上键
   this.listIndex--;
   if(this.listIndex<0){
    this.listIndex=this.arr.length-1;
   }
   this.wd=this.arr[this.listIndex];
   }
   else if(event.keyCode==40){
   //说明你按的是下键
   this.listIndex++;
   if(this.listIndex>this.arr.length-1){
    this.listIndex=0;
   }
   this.wd=this.arr[this.listIndex];
   }else if(event.keyCode==13){
   //如果你按的是enter,那么就跳转到百度搜索结果
   window.open(\"https://www.baidu.com/s?wd=\"+this.wd);
   }
 
  }
  }
 }
</script>
 
<style scoped>
 
</style>

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

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容