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 相关文章推荐
JS基础之undefined与null的区别分析
Aug 08 Javascript
javascript中的注释使用与注意事项小结
Sep 20 Javascript
js实现倒计时时钟的示例代码
Dec 17 Javascript
浅谈js的html元素的父节点,子节点
Aug 06 Javascript
Angular中ng-bind和ng-model的区别实例详解
Apr 10 Javascript
vue加载自定义的js文件方法
Mar 13 Javascript
layer.confirm取消按钮绑定事件的方法
Aug 17 Javascript
bootstrap-table实现表头固定以及列固定的方法示例
Mar 07 Javascript
JS获取动态添加元素的方法详解
Jul 31 Javascript
JavaScript和TypeScript中的void的具体使用
Sep 12 Javascript
node.js中事件触发器events的使用方法实例分析
Nov 23 Javascript
Jquery+AJAX实现无刷新上传并重命名文件操作示例【PHP后台接收】
May 29 jQuery
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
纯真IP数据库的应用 IP地址转化成十进制
2009/06/14 PHP
php explode函数实例代码
2012/02/27 PHP
php实现cookie加密的方法
2015/03/10 PHP
Yii2创建表单(ActiveForm)方法详解
2016/07/23 PHP
BOOM vs RR BO5 第四场 2.14
2021/03/10 DOTA
JavaScript DOM 学习第九章 选取范围的介绍
2010/02/19 Javascript
Js base64 加密解密介绍
2013/10/11 Javascript
jquery实现可拖动DIV自定义保存到数据的实例
2013/11/20 Javascript
JS应用正则表达式转换大小写示例
2014/09/18 Javascript
node.js中的path.join方法使用说明
2014/12/08 Javascript
封装了jQuery的Ajax请求全局配置
2015/02/05 Javascript
基于html5和nodejs相结合实现websocket即使通讯
2015/11/19 NodeJs
JavaScript实现输入框(密码框)出现提示语
2016/01/12 Javascript
Bootstrap中定制LESS-颜色及导航条(推荐)
2016/11/21 Javascript
AngularJS指令中的绑定策略实例分析
2016/12/14 Javascript
JS实现上传图片实时预览功能
2017/05/22 Javascript
JS组件系列之Gojs组件 前端图形化插件之利器
2017/11/29 Javascript
微信小程序简单实现form表单获取输入数据功能示例
2017/11/30 Javascript
vuex与组件联合使用的方法
2018/05/10 Javascript
微信小程序搜索功能(附:小程序前端+PHP后端)
2019/02/28 Javascript
对layer弹出框中icon数字参数的说明介绍
2019/09/04 Javascript
vue中的mescroll搜索运用及各种填坑处理
2019/10/30 Javascript
如何通过javaScript去除字符串两端的空白字符
2020/02/06 Javascript
Python的re模块正则表达式操作
2016/05/25 Python
完美解决Python matplotlib绘图时汉字显示不正常的问题
2019/01/29 Python
python3+selenium自动化测试框架详解
2019/03/17 Python
关于python多重赋值的小问题
2019/04/17 Python
Django数据库类库MySQLdb使用详解
2019/04/28 Python
详解python中eval函数的作用
2019/10/22 Python
详解python polyscope库的安装和例程
2020/11/13 Python
英国著名音像制品和图书游戏购物网站:Zavvi
2016/08/04 全球购物
公司外出活动方案
2014/08/14 职场文书
党的群众路线教育实践活动通讯稿
2014/09/10 职场文书
学生不参加考试检讨书
2015/02/19 职场文书
小学教师个人工作总结2015
2015/04/20 职场文书
win10频率超出范围怎么办?win10老显示超出工作频率范围的解决方法
2022/07/07 数码科技