Maison > interface Web > js tutoriel > le corps du texte

Partage de code pour JavaScript afin d'implémenter la fonction de recherche frontale en temps réel (photo)

黄舟
Libérer: 2017-04-18 09:47:58
original
6206 Les gens l'ont consulté

这篇文章主要为大家详细介绍了JavaScript实现前端实时搜索功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

1.基本布局:


<p class="searcher">
  <p class="searcher-main">
   <i><img  src="img/icon/icon-search-map.png"/ alt="Partage de code pour JavaScript afin d'implémenter la fonction de recherche frontale en temps réel (photo)" ></i>
   <input class="searcher-text" placeholder="请输入档口名称"></input>
  </p>
  <p class="searcher-cancel">取消</p>
</p>
Copier après la connexion

这里涉及一个问题如何将搜索图标放入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;
  }
Copier après la connexion

2.step-1:

3.js部分

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

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


 //监听input框,实时渲染
 $(&#39;.searcher-text&#39;).on(&#39;input&#39;, function() {
  initSearchList();
  });
Copier après la connexion

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


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

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

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


function replaceIllegalStr(str) {
 var reg;
 var illegal_list = ["/", "\\",
  "[", "]",
  "{", "}",
  "<", ">",
  "<", ">",
  "「", "」",
  ":", ";",
  "、", "•",
  "^", "&#39;", "\"",
  "\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] == &#39;\\&#39; || illegal_list[i] == &#39;[&#39;) {
    reg = new RegExp(&#39;\\&#39; + illegal_list[i], "g");
   } else {
    reg = new RegExp(illegal_list[i], "g");
   }
   str = str.replace(reg, &#39;&#39;);
  }
 }
 return str.trim();
}
Copier après la connexion

4.step-2:

Partage de code pour JavaScript afin dimplémenter la fonction de recherche frontale en temps réel (photo)

5.缓存

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


//设置缓存
 epm.setLocalItem = function(key, value) {
  if (window.localStorage) {
   localStorage.setItem(key, value);
  } else {
   //后备方案
   setCookie(key, value);
  }
 };
Copier après la connexion


//提取缓存
 epm.getLocalItem = function(key) {
  if (window.localStorage) {
   return localStorage.getItem(key);
  } else {
   //后备方案
   return getCookie(key);
  }
 };
Copier après la connexion


//删除缓存
 epm.removeLocalItem = function(key) {
  if (window.localStorage) {
   localStorage.removeItem(key);
  } else {
   //后备方案
   removeCookie(key);
  }
 };
Copier après la connexion

Partage de code pour JavaScript afin dimplémenter la fonction de recherche frontale en temps réel (photo)

6.step-3

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


Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!