ホームページ >ウェブフロントエンド >jsチュートリアル >jQuery の select プラグインを使用して非同期リアルタイム検索を実装する方法

jQuery の select プラグインを使用して非同期リアルタイム検索を実装する方法

黄舟
黄舟オリジナル
2017-10-26 10:30:272190ブラウズ

この記事では主に jquery select プラグインの非同期リアルタイム検索サンプル コードを紹介します。必要な方は参考にしてください

1. まず効果を見てください。

2. このプラグインを作成した理由。

1. データ量が多すぎて(数千、数万)、一度に読み込むことができない。

2. 既存のプラグインは異なり、機能要件を満たすことができません。

3.美観性とコントロール性が不十分。

3. 使用方法。

1.htmlとjs


 <select id="unit"></select>
 <script type="text/javascript" src="/demo/thirdparty/jquery/jquery-1.8.3.min.js"></script>
 <script src="/demo/thirdparty/pheker/ajaxselect.js"></script>

2.例。


# 使用实例
    var initUrl = "/demo/defineDict.do?method=getEnterpriseDict&unitName="+encodeURIComponent(encodeURIComponent("xx无烟煤矿业集团有限责任公司"));
    var ajaxUrl = "/demo/defineDict.do?method=getEnterpriseDict&unitName=";
    var $select = $("#ajaxselect").ajaxselect({
      initUrl:initUrl,
      ajaxUrl:ajaxUrl,
      defkv:[&#39;id&#39;,&#39;text&#39;],
      selected:0,
    },function(filterData,isInit){
      //filter
      console.log(filterData);
    },function(cbData,isInit){
      //callback
      console.log(cbData);
    });
    $select.on("change", function(){
      console.log(this.value);
    });

3. 詳細な設定。


var defcfg = {
  initUrl:&#39;&#39;,      //初始化请求地址
  ajaxUrl:&#39;&#39;,      //异步请求地址
  defkv:[],      //返回数据 的key
  delay:200,      //ajax回调 延时
  width:200,      //input 宽度
  height:30,      //input 高度
  selected:-1,    //初始化数据 默认选中项,-1为不选中
  limit:20,      //最大显示条数,0为不限制
  maxheight:250,    //最大显示高度
  hoverbg:&#39;#189FD9&#39;,  //悬浮背景色
  activebg:&#39;#5FB878&#39;,  //选中项背景色
  style:&#39;&#39;      //自定义样式
};

他にもいくつかAPIがありますので、詳しくは参考リンクとソースコードをご覧ください。

4: ステートメント:

このプラグインは既存のプラグインに基づいており、独自のニーズに応じて変更されています。軽微な問題がある場合は、ご自身でソースコードを修正してください。

非同期検索が必要ない場合は、layui や select2 などの他のプラグインも良い選択です。

さらに、このプラグインは jquery に依存しています。

概要

以上がjQuery の select プラグインを使用して非同期リアルタイム検索を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。