vue实现百度搜索功能的方法-创新互联

小编给大家分享一下vue实现百度搜索功能的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:主机域名网站空间、营销软件、网站建设、福安网站维护、网站推广。

vue实现百度搜索功能的具体代码如下

最终效果:

vue实现百度搜索功能的方法

Baidusearch.vue所有代码:

<template>
 <div>
  <div class="container" id="app">
  <div class="page-header">
   <h3 class=" text-center text-primary">百度搜索案例</h3>
  </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>

以上是“vue实现百度搜索功能的方法”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联成都网站设计公司行业资讯频道!

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。

当前文章:vue实现百度搜索功能的方法-创新互联
当前链接:https://www.cdcxhl.com/article30/ddioso.html

成都网站建设公司_创新互联,为您提供动态网站网站营销App设计网站制作微信小程序网站建设

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

外贸网站建设