• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >JavaScript > JavaScript实现前端实时搜索功能

JavaScript实现前端实时搜索功能

作者:zhangr16xyz 字体:[增加 减小] 来源:互联网 时间:2017-05-11

zhangr16xyz通过本文主要向大家介绍了javascript前端开发,javascript前端,javascript前端框架,web前端javascript,javascript搜索等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

大部分页面都具备搜索功能。而作为前端,我们的目的只是将用户输入的内容返回给后台而后呈现反馈数据给用户,具体实现如下:

1.基本布局:

<div class="searcher">
  <p class="searcher-main">
   <i><img src="img/icon/icon-search-map.png"/></i>
   <input class="searcher-text" placeholder="请输入档口名称"></input>
  </p>
  <p class="searcher-cancel">取消</p>
</div>
</div>

这里涉及一个问题如何将搜索图标放入input中,网上有相关资料不做赘述:

  .searcher {
   background: rgba(255, 255, 255, 0);
   position: fixed;
   z-index: 999;
   width: 100%;
   height: 6rem;
   text-align: center;
   font-size: 1.6rem;
  }

  .searcher-main {
   background: #F4F4F4;
   position: absolute;
   left: 50%;
   top: 1.2rem;
   margin-left: -45%;
   border-radius: 1.6rem;
   width: 80%;
   height: 3rem;
   line-height: 3rem;
  }    

  .searcher-text {
   width: 80%;
   text-align: center;
   border: none;
   outline: none;
   background: #F4F4F4;
  }

  .searcher-cancel {
   position: absolute;
   width: 10%;
   height: 3rem;
   line-height: 3rem;
   color: #929292;
   top: 1.2rem;
   right: 1rem;
  }

</div>

2.step-1:

3.js部分

这里要安利IE9以上的oninput事件

onchange事件只在键盘或者鼠标操作改变对象属性,且失去焦点时触发,脚本触发无效。
onkeydown/onkeypress/onkeyup在处理复制、粘贴、拖拽、长按键(按住键盘不放)等细节上并不完善。
onpropertychange不用考虑是否失去焦点,不管js操作还是键盘鼠标手动操作,只要HTML元素属性发生改变即可立即捕获到。遗憾的是,onpropertychange为IE专属的。

 //监听input框,实时渲染
 $('.searcher-text').on('input', function() {
  initSearchList();
  });
</div>

JQ一般都是用这种+=html的方法,虽然累赘不过通过url或者tag标签里属性传参较容易理解。

  //渲染搜索列表
  function initSearchList() {
   var List = $('.searcher-land ul');
   var params = {};
   //搜索过滤字符
   var SEARCH_KEY = $('.searcher-text').val()
   params['action'] = 'get_search_key_list';
   params['market_iid'] = 1001;
   params['search_type'] = TYPE;
   params['search_key'] = replaceIllegalStr(SEARCH_KEY);

   epm.ajax(params, function(result) {
    console.log(result);
    console.log(TYPE)
    var html = '';
    List.html('');
    //有结果
    if(result.data.length > 0) {
     $.each(result.data, function(index, value) {
      goodName = value['goods_name'];
      shopName = value['shop_name'];
      //判断Name类型
      itemName = (goodName) ? goodName : shopName;
      html += '<li class="goods-list">' + itemName + '</li>'
     });
     $('.searcher-list').html(html);
    }
    //无结果
    else {
     html = '<div class="no-goods">暂时无法找到此选项~</div>';
     $('.searcher-list').html(html);
    }
   });
  }

</div>

注意这里有一个replaceIllegalStr()方法,类似正则,目的是过滤掉一些无用的符号以免给后端接收数据带来不必要的麻烦。

function replaceIllegalStr(str) {
 var reg;
 var illegal_list = ["/", "\\",
  "[", "]",
  "{", "}",
  "<", ">",
  "<", ">",
  "「", "」",
  ":", ";",
  "、", "•",
  "^", "'", "\"",
  "\r", "\r\n", "\\n", "\n"];
 for (var i = 0; i < illegal_list.length; i++) {
  if (str.indexOf(illegal_list[i]) >= 0) {
   if (illegal_list[i] == '\\' || illegal_list[i] == '[') {
    reg = new RegExp('\\' + illegal_list[i], "g");
   } else {
    reg = new RegExp(illegal_list[i], "g");
   }
   str = str.replace(reg, '');
  }
 }
 return str.trim();
}
</div>

4.step-2:

这里写图片描述

5.缓存

这里我们将点击的数据保存在本地缓存里,供取用呈现:
注: epm是自己封装的一个方法与属性的对象

//设置缓存
 epm.setLocalItem = function(key, value) {
  if (window.localStorage) {
   localStorage.setItem(key, value);
  } else {
   //后备方案
   setCookie(key, value);
  }
 };
</div>
//提取缓存
 epm.getLocalItem = function(key) {
  if (window.localStorage) {
   return localStorage.getItem(key);
  } else {
   //后备方案
   return getCookie(key);
  }
 };
</div>
//删除缓存
 epm.removeLocalItem = function(key) {
  if (window.localStorage) {
   localStorage.removeItem(key);
  } else {
   //后备方案
   removeCookie(key);
  }
 };
</div>

这里写图片描述

6.step-3

得到点击的相应的缓存词里的value,再次发送ajax:

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

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • JavaScript实现前端实时搜索功能
  • JavaScript优化以及前段开发小技巧
  • 前端编码规范(3)JavaScript 开发规范

相关文章

  • 2017-05-11原生Javascript插件开发实践
  • 2017-05-11微信小程序开发之从相册获取图片 使用相机拍照 本地图片上传
  • 2017-05-11JavaScript获取中英文混合字符串长度的方法示例
  • 2017-09-08es6的Generotor 函数学习
  • 2017-09-183种页面加载完成后再执行JS的jquery写法以及区别说明
  • 2017-05-11基于JavaScript实现的快速排序算法分析
  • 2017-05-11实例分析nodejs模块xml2js解析xml过程中遇到的坑
  • 2017-05-11jQuery插件form-validation-engine正则表达式操作示例
  • 2017-05-11javascript实现秒表计时器的制作方法
  • 2017-05-11数组Array的排序sort方法

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • jquery实时获取时间的简单实例
    • 微信小程序 本地数据存储实例详解
    • Bootstrap表单制作代码
    • JS轮播图中缓动函数的封装
    • jQuery实现级联下拉框实战(5)
    • JS ES6多行字符串与连接字符串的表示方法
    • Bootstrap页面标题Page Header的实现方法
    • 轻松学习Javascript闭包
    • 详解Jquery EasyUI tree 的异步加载(遍历指定文件夹,根据文件夹内的文件生成tree)
    • JS实现复选框的全选和批量删除功能

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有