国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

bootstrap suggest搜索建議插件使用詳解

2019-11-19 17:02:28
字體:
供稿:網(wǎng)友

近日因工作需要看了下此插件。

首先下載bootstrap js包。添加此插件的引用。注意css樣式要引用,不能忘記。

前臺頁面代碼,因為樓主做的是選項卡切換查詢不同的結(jié)果。

<tr>  <th style="background: #fff;" width="30%">類型:</th>       <td width="70%">         <select class="selectpicker show-tick" id="SlideType">           <option value="2">生活</option>           <option value="1">首頁</option>           <option value="3">作品</option>         </select>       </td>     </tr>     <tr>       <th style="background:#fff">標(biāo)題:</th>       <td>          <div class="input-group" style="width:300px">           <input type="text" class="form-control" id="Title">           <div class="input-group-btn">             <button type="button" class="btn btn-white dropdown-toggle" data-toggle="dropdown">               <span class="caret"></span>             </button>             <ul class="dropdown-menu dropdown-menu-right" role="menu"></ul>           </div>           <!-- /btn-group -->         </div>       </td></tr> 
 //搜索建議框      /* $('#Title').keyup(function () {         var obj = $('#SlideType').val();         var txtName = $('#Title').val().trim();         $.post("/Slide/LoadSelect", { Index: obj, Name: txtName }, function (data) {           if (data != null) {             data = JSON.parse(data);             var testdataBsSuggest = $("#Title").bsSuggest({               indexId: 0,               indexKey: 1,               data: {                 "value": data               }             }).on('onSetSelectValue', function (e, data) {               var url = "";               switch (obj) {                 case "1": url = "";                   break;                 case "2": url = "HomeLife/HomeKnowledgeDetails?InfoGuid=";                   break;                 case "3": url = "";                   break;                 default:               }               $("#Url").val(url + data.id);             });           }         });       });*/

這是樓主根據(jù)不同的選項請求查詢不同的數(shù)據(jù),再在結(jié)果中搜索

下面說的就是第二種,是搜索插件內(nèi)部的請求。

如下:

function GetSuggest(obj) {      var testBsSuggest = $("#Title").bsSuggest({        url: "/Slide/LoadSelect?Keyword=" + obj + "",        getDataMethod: "firstByUrl",//獲取數(shù)據(jù)的方式,url:一直從url請求;data:從 options.data 獲取;firstByUrl:第一次從Url獲取全部數(shù)據(jù),之后從options.data獲取        effectiveFieldsAlias: { Title: "標(biāo)題" },        searchFields: ["Title"],        idField: "InfoGuid",        keyField: "Title",        effectiveFields: ["Title"],        showHeader: true,//顯示 header        showBtn: true,   //不顯示下拉按鈕        delayUntilKeyup: false, //獲取數(shù)據(jù)的方式為 firstByUrl 時,延遲到有輸入/獲取到焦點時才請求數(shù)據(jù)      }).on('onSetSelectValue', function (e, keyword) {        var url = "";        switch (obj) {          case "1": url = "";            break;          case "2": url = UrlJump(keyword.id);            break;          case "3": url = "";            break;        }        $("#Url").val(url + keyword.id.substring(0, keyword.id.length - 1));      });    }

對應(yīng)的后臺代碼:

最終頁面顯示的結(jié)果。

看看以下配置說明可以更改不同的需求。

####方法調(diào)用禁用提示: $("input#test").bsSuggest("disable");啟用提示: $("input#test").bsSuggest("enable");銷毀插件: $("input#test").bsSuggest("destroy");查看版本:$("input#test").bsSuggest("version");####事件監(jiān)聽onDataRequestSuccess: 當(dāng) AJAX 請求數(shù)據(jù)成功時觸發(fā),并傳回結(jié)果到第二個參數(shù)onSetSelectValue:當(dāng)從下拉菜單選取值時觸發(fā),并傳回設(shè)置的數(shù)據(jù)到第二個參數(shù)onUnsetSelectValue:當(dāng)設(shè)置了 idField,且自由輸入內(nèi)容時觸發(fā)(與背景警告色顯示同步)$("#test")  .on('onDataRequestSuccess', function (event, result) {    console.log(result);  })  .on('onSetSelectValue', function (e, keyword) {    console.log('onSetSelectValue: ', keyword);  })  .on('onUnsetSelectValue', function (e) {    console.log('onUnsetSelectValue');  });

配置參數(shù)

參數(shù)列表中的值均為插件默認(rèn)值

var defaultOptions = {  url: null,           //請求數(shù)據(jù)的 URL 地址  jsonp: null,          //設(shè)置此參數(shù)名,將開啟jsonp功能,否則使用json數(shù)據(jù)結(jié)構(gòu)  data: {           value: []          },               //提示所用的數(shù)據(jù),注意格式  indexId: 0,           //每組數(shù)據(jù)的第幾個數(shù)據(jù),作為input輸入框的 data-id,設(shè)為 -1 且 idField 為空則不設(shè)置此值  indexKey: 0,          //每組數(shù)據(jù)的第幾個數(shù)據(jù),作為input輸入框的內(nèi)容  idField: '',          //每組數(shù)據(jù)的哪個字段作為 data-id,優(yōu)先級高于 indexId 設(shè)置(推薦)  keyField: '',          //每組數(shù)據(jù)的哪個字段作為輸入框內(nèi)容,優(yōu)先級高于 indexKey 設(shè)置(推薦)  /* 搜索相關(guān) */  autoSelect: true,        //鍵盤向上/下方向鍵時,是否自動選擇值  allowNoKeyword: true,      //是否允許無關(guān)鍵字時請求數(shù)據(jù)  getDataMethod: 'firstByUrl',  //獲取數(shù)據(jù)的方式,url:一直從url請求;data:從 options.data 獲取;firstByUrl:第一次從Url獲取全部數(shù)據(jù),之后從options.data獲取  delayUntilKeyup: false,     //獲取數(shù)據(jù)的方式 為 firstByUrl 時,是否延遲到有輸入時才請求數(shù)據(jù)  ignorecase: false,       //前端搜索匹配時,是否忽略大小寫  effectiveFields: [],      //有效顯示于列表中的字段,非有效字段都會過濾,默認(rèn)全部。  effectiveFieldsAlias: {},    //有效字段的別名對象,用于 header 的顯示  searchFields: [],        //有效搜索字段,從前端搜索過濾數(shù)據(jù)時使用,但不一定顯示在列表中。effectiveFields 配置字段也會用于搜索過濾  twoWayMatch: true,       // 是否雙向匹配搜索。為 true 即輸入關(guān)鍵字包含或包含于匹配字段均認(rèn)為匹配成功,為 false 則輸入關(guān)鍵字包含于匹配字段認(rèn)為匹配成功  multiWord: false,        //以分隔符號分割的多關(guān)鍵字支持  separator: ',',         //多關(guān)鍵字支持時的分隔符,默認(rèn)為半角逗號  /* UI */  autoDropup: false,       //選擇菜單是否自動判斷向上展開。設(shè)為 true,則當(dāng)下拉菜單高度超過窗體,且向上方向不會被窗體覆蓋,則選擇菜單向上彈出  autoMinWidth: false,      //是否自動最小寬度,設(shè)為 false 則最小寬度不小于輸入框?qū)挾? showHeader: false,       //是否顯示選擇列表的 header。為 true 時,有效字段大于一列則顯示表頭  showBtn: true,         //是否顯示下拉按鈕  inputBgColor: '',        //輸入框背景色,當(dāng)與容器背景色不同時,可能需要該項的配置  inputWarnColor: 'rgba(255,0,0,.1)', //輸入框內(nèi)容不是下拉列表選擇時的警告色  listStyle: {    'padding-top': 0,    'max-height': '375px',    'max-width': '800px',    'overflow': 'auto',    'width': 'auto',    'transition': '0.3s',    '-webkit-transition': '0.3s',    '-moz-transition': '0.3s',    '-o-transition': '0.3s'  },               //列表的樣式控制  listAlign: 'left',       //提示列表對齊位置,left/right/auto  listHoverStyle: 'background: #07d; color:#fff', //提示框列表鼠標(biāo)懸浮的樣式  listHoverCSS: 'jhover',     //提示框列表鼠標(biāo)懸浮的樣式名稱  clearable: false,        // 是否可清除已輸入的內(nèi)容  /* key */  keyLeft: 37,          //向左方向鍵,不同的操作系統(tǒng)可能會有差別,則自行定義  keyUp: 38,           //向上方向鍵  keyRight: 39,          //向右方向鍵  keyDown: 40,          //向下方向鍵  keyEnter: 13,          //回車鍵  /* methods */    fnProcessData: processData,   //格式化數(shù)據(jù)的方法,返回數(shù)據(jù)格式參考 data 參數(shù)  fnGetData: getData,       //獲取數(shù)據(jù)的方法,無特殊需求一般不作設(shè)置  fnAdjustAjaxParam: null,    //調(diào)整 ajax 請求參數(shù)方法,用于更多的請求配置需求。如對請求關(guān)鍵字作進(jìn)一步處理、修改超時時間等  fnPreprocessKeyword: null    //搜索過濾數(shù)據(jù)前,對輸入關(guān)鍵字作進(jìn)一步處理方法。注意,應(yīng)返回字符串};

至此結(jié)束。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 渑池县| 清丰县| 上栗县| 泾阳县| 安陆市| 瓮安县| 漾濞| 康平县| 赫章县| 仁化县| 赣州市| 鸡西市| 云南省| 阳曲县| 佛山市| 类乌齐县| 永城市| 亳州市| 蒲江县| 襄垣县| 新巴尔虎右旗| 松桃| 湾仔区| 台北市| 和政县| 宁夏| 光泽县| 华蓥市| 巫山县| 东阳市| 镇巴县| 长垣县| 育儿| 常德市| 房产| 陕西省| 乐至县| 郴州市| 大庆市| 东丽区| 汉阴县|