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


Posted in Javascript onJune 21, 2017

一、前期准备

网上大神已经做过这个功能https://github.com/lavyun/vue-demo-search 这自己仅实现搜索功能
为了使用百度实现搜索功能,首先搞清楚下拉数据和搜索功能的数据接口

01、提示数据获取地址

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

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

提示数据获取地址.png

然后简化一下:

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

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

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

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

02:搜索功能实现地址

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

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

搜索地址.png

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

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

简化地址.png

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

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

测试.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遍历提示数据

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

提示数据.png

然后selectDown和selectUp实现上下选中数据,当按下回车键时,实现搜索
完整代码:https://github.com/yanqiangmiffy/baidu-search

三、实现效果

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

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

Javascript 相关文章推荐
jquery ready(fn)事件使用介绍
Aug 21 Javascript
JavaScript中5种调用函数的方法
Mar 12 Javascript
JS中动态创建元素的三种方法总结(推荐)
Oct 20 Javascript
js实现的xml对象转json功能示例
Dec 24 Javascript
JS中正则表达式全局匹配模式 /g用法详解
Apr 01 Javascript
详解Vue中状态管理Vuex
May 11 Javascript
jquery.validate.js 多个相同name的处理方式
Jul 10 jQuery
js图片放大镜实例讲解(必看篇)
Jul 17 Javascript
vue+moment实现倒计时效果
Aug 26 Javascript
Vue 实现一个命令式弹窗组件功能
Sep 25 Javascript
vue图片上传组件使用详解
Dec 23 Javascript
深入理解Vue的数据响应式
May 15 Vue.js
vue2.0中click点击当前li实现动态切换class
Jun 21 #Javascript
jQuery实现可拖动进度条实例代码
Jun 21 #jQuery
详解Vue整合axios的实例代码
Jun 21 #Javascript
详解在vue-cli项目中安装node-sass
Jun 21 #Javascript
详解vue-cli中配置sass
Jun 21 #Javascript
详解如何在vue中使用sass
Jun 21 #Javascript
JS表单提交验证、input(type=number) 去三角 刷新验证码
Jun 21 #Javascript
You might like
PHP操作mysql函数详解,mysql和php交互函数
2011/05/19 PHP
yii框架源码分析之创建controller代码
2011/06/28 PHP
简单的方法让你的后台登录更加安全(php中加session验证)
2012/08/22 PHP
在win7中搭建Linux+PHP 开发环境
2014/10/08 PHP
编写PHP程序检查字符串中的中文字符个数的实例分享
2016/03/17 PHP
Yii2框架实现登陆添加验证码功能示例
2018/07/12 PHP
javascript实现的网页局布刷新效果
2008/12/01 Javascript
关于JavaScript的一些看法
2009/05/27 Javascript
javascript Keycode对照表
2009/10/24 Javascript
Javscript删除数组中指定元素并返回新数组
2014/03/06 Javascript
JS实现CheckBox复选框全选全不选功能
2015/05/06 Javascript
javascript实现淡蓝色的鼠标拖动选择框实例
2015/05/09 Javascript
javascript表单事件处理方法详解
2016/05/15 Javascript
基于Javascript实现的不重复ID的生成器
2016/12/25 Javascript
深入理解JavaScript中的预解析
2017/01/04 Javascript
jQuery表单元素选择器代码实例
2017/02/06 Javascript
jQuery滑动到底部加载下一页数据的实例代码
2017/05/22 jQuery
Angular.js初始化之ng-app的自动绑定与手动绑定详解
2017/07/31 Javascript
React-Native中props具体使用详解
2017/09/04 Javascript
nodejs搭建本地服务器轻松解决跨域问题
2018/03/21 NodeJs
React.js绑定this的5种方法(小结)
2018/06/05 Javascript
微信小程序 导入图标实现过程详解
2019/10/11 Javascript
用python + hadoop streaming 分布式编程(一) -- 原理介绍,样例程序与本地调试
2014/07/14 Python
python通过文件头判断文件类型
2015/10/30 Python
Linux下通过python访问MySQL、Oracle、SQL Server数据库的方法
2016/04/23 Python
python pandas修改列属性的方法详解
2018/06/09 Python
安装完Python包然后找不到模块的解决步骤
2020/02/13 Python
Python爬虫中Selenium实现文件上传
2020/12/04 Python
Priority Pass机场贵宾室会籍计划:全球超过1200间机场贵宾室
2018/08/26 全球购物
城市轨道专业个人求职信范文
2013/09/23 职场文书
网络编辑岗位职责
2014/03/18 职场文书
家教广告词
2014/03/19 职场文书
优秀共青团员事迹材料
2014/12/25 职场文书
清洁工个人总结
2015/03/04 职场文书
农业项目合作意向书
2015/05/08 职场文书
2016年重阳节慰问信
2015/12/01 职场文书