使用 Vue.js 仿百度搜索框的实例代码


Posted in Javascript onMay 09, 2017

整理文档,搜刮出一个使用 Vue.js 仿百度搜索框的实例代码,稍微整理精简一下做下分享。

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <title>Vue demo</title>
  <style type="text/css">
  .bg {
    background: #ccc;
  }
  </style>
  <script src="https://cdn.bootcss.com/vue/2.1.7/vue.min.js"></script>
  <script src="https://cdn.bootcss.com/vue-resource/1.3.1/vue-resource.min.js"></script>
  <script type="text/javascript">
  window.onload = function() {
    new Vue({
      el: '#box',
      data: {
        inputText: '',
        text: '',
        nowIndex: -1,
        result: []
      },
      methods: {
        show: function(ev) {
          if (ev.keyCode == 38 || ev.keyCode == 40) {
            if (this.nowIndex < -1){
              return;
            }
            if (this.nowIndex != this.result.length && this.nowIndex != -1) {
              this.inputText = this.result[this.nowIndex];
            }
            return;
          }
          if (ev.keyCode == 13) {
            window.open('https://www.baidu.com/s?wd=' + this.inputText, '_blank');
            this.inputText = '';
          }
          this.text = this.inputText;
          this.$http.jsonp('https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su', {
            params: {
              wd: this.inputText
            },
            jsonp: 'cb'
          }).then(res => {
            this.result = res.data.s;
          })
        },
        down: function() {
          this.nowIndex++;
          if (this.nowIndex == this.result.length) {
            this.nowIndex = -1;
            this.inputText = this.text;
          }
        },
        up: function() {
          this.nowIndex--;
          if (this.nowIndex < -1){
            this.nowIndex = -1;
            return;
          }
          if (this.nowIndex == -1) {
            this.nowIndex = this.result.length;
            this.inputText = this.text;
          }
        }
      }
    });
  }
  </script>
</head>

<body>
  <div id="box">
    <input type="text" placeholder="请输入搜索内容" v-model='inputText' @keyup='show($event)' @keydown.down='down()' @keydown.up.prevent='up()'>
    <ul>
      <li v-for="(item, index) in result" :class='{bg: index==nowIndex}'>
        {{item}}
      </li>
    </ul>
  </div>
</body>

</html>

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

Javascript 相关文章推荐
jquery实现居中弹出层代码
Aug 25 Javascript
JavaScript立即执行函数的三种不同写法
Sep 05 Javascript
jQuery中addClass()方法用法实例
Jan 05 Javascript
你所不了解的javascript操作DOM的细节知识点(一)
Jun 17 Javascript
微信小程序 教程之小程序配置
Oct 17 Javascript
BootStrap table使用方法分析
Nov 08 Javascript
360提示[高危]使用存在漏洞的JQuery版本的解决方法
Oct 27 jQuery
微信小程序动态生成二维码的实现代码
Jul 25 Javascript
用npm-run实现自动化任务的方法示例
Jan 14 Javascript
js prototype深入理解及应用实例分析
Nov 25 Javascript
vue实现随机验证码功能(完整代码)
Dec 10 Javascript
Vue 样式切换及三元判断样式关联操作
Aug 09 Javascript
详解如何将angular-ui的图片轮播组件封装成一个指令
May 09 #Javascript
使用ES6语法重构React代码详解
May 09 #Javascript
JQuery实现定时刷新功能代码
May 09 #jQuery
React.js中常用的ES6写法总结(推荐)
May 09 #Javascript
js上传图片预览的实现方法
May 09 #Javascript
react开发中如何使用require.ensure加载es6风格的组件
May 09 #Javascript
Vue2单一事件管理组件通信
May 09 #Javascript
You might like
php下关于中英数字混排的字符串分割问题
2010/04/06 PHP
PHP中的多行字符串传递给JavaScript的两种方法
2014/06/19 PHP
PHP输出缓冲控制Output Control系列函数详解
2015/07/02 PHP
JavaScript中的Document文档对象
2008/01/16 Javascript
javascript 嵌套的函数(作用域链)
2010/03/15 Javascript
jquery select下拉框操作的一些说明
2010/04/02 Javascript
jQuery 菜单随滚条改为以定位方式(固定要浏览器顶部)
2012/05/24 Javascript
html5 canvas js(数字时钟)实例代码
2013/12/23 Javascript
详解JavaScript中setSeconds()方法的使用
2015/06/11 Javascript
JS实现网页每隔3秒弹出一次对话框的方法
2015/11/09 Javascript
js正则表达式replace替换变量方法
2016/05/21 Javascript
js实现轮播图的两种方式(构造函数、面向对象)
2017/09/30 Javascript
在vue项目中使用sass的配置方法
2018/03/20 Javascript
javascriptvoid(0)含义以及与&quot;#&quot;的区别讲解
2019/01/19 Javascript
通过循环优化 JavaScript 程序
2019/06/24 Javascript
微信小程序实现上拉加载功能示例【加载更多数据/触底加载/点击加载更多数据】
2020/05/29 Javascript
[01:25]2014DOTA2国际邀请赛 zhou分析LGD比赛情况
2014/07/14 DOTA
python模拟登录百度贴吧(百度贴吧登录)实例
2013/12/18 Python
Python生成pdf文件的方法
2014/08/04 Python
Python cookbook(数据结构与算法)将名称映射到序列元素中的方法
2018/03/22 Python
Python多进程入门、分布式进程数据共享实例详解
2019/06/03 Python
Python assert语句的简单使用示例
2019/07/28 Python
基于CSS3实现的黑色个性导航菜单效果
2015/09/14 HTML / CSS
英国假睫毛购买网站:FalseEyelashes.co.uk
2018/05/23 全球购物
比利时家具购买网站:Home24
2019/01/03 全球购物
UNIX文件名称有什么规定
2013/03/25 面试题
家长给孩子的表扬信
2014/01/17 职场文书
母亲追悼会答谢词
2014/01/27 职场文书
新教师工作感言
2014/02/16 职场文书
受伤赔偿协议书
2014/09/24 职场文书
2015圣诞节贺卡寄语
2015/03/24 职场文书
2015年志愿者服务工作总结
2015/04/20 职场文书
七一慰问简报
2015/07/20 职场文书
如何给HttpServletRequest增加消息头
2021/06/30 Java/Android
CSS3实现360度循环旋转功能
2022/02/12 HTML / CSS
vue实力踩坑之push当前页无效
2022/04/10 Vue.js