HTML5新增的標籤datalist實作輸入中文/拼音首字母時,自動進入資料庫模糊查詢,並傳回對應的結果,產生datalist,由於在輸入框中的輸入內容發生變化時,datalist會自動觸發下拉框,解決方案非常好,下面透過本文給大家分享實例代碼,需要的的朋友參考下吧
最近專案中涉及到一個小功能,當客戶選擇供應商時,由於供應商數量較多(大概3000個左右),因此直接產生下拉框顯然不現實,所以就更換解決方案,打算藉助HTML5新增的標籤datalist來實現輸入中文/拼音首字母時,自動進入資料庫模糊查詢,並返回相應的結果,產生datalist,由於在輸入框中的輸入內容髮生變化時, datalist會自動觸發下拉框,所以使用起來比select更方便。前端部分程式碼如下:
Html Code:
库存下拉框测试
下拉框测试
测试数据(默认均为d00001):
按 供应商名动态匹配(中文或者拼音均可):
昆山市大陆配件有限公司 ksdlpjyxgs
亿真企业有限公司 yzqyyxgs
泰州市安誊轴皮厂(集团厂) tzsatzpc(jtc)
JavaScript Code:
var listobj=null; //datalist对象 var requestItem=null; //后台返回的json数据中所需的key值 var inputContent=null; //input标签对象 /**search()说明: * inputID: input标签的ID * datalistID: datalist标签的ID * itemName: 后台返回的json数据中所需的key值(仅需表格中中文字段的属性名) * */ function search(inputID,datalistID,itemName) { inputContent=document.getElementById(inputID); var datalist=document.getElementById(datalistID); //防止在无输入内容的情况下产生遗留下拉选项 if(inputContent.value.length==0||inputContent.value==" ") { var sub=datalist.childNodes; if(sub.length>0) { for (var i =sub.length-1; i>=0 ; i--) { datalist.removeChild(sub[i]); } } listobj=null; requestItem=null; inputContent.value=null; return false; } //全局变量赋值 listobj=datalist; requestItem=itemName; var data=""; var url=""; if(/^[a-zA-Z]*$/.test(inputContent.value)) { //检测出是拼音首字母 data="type=searchWords¶m="+inputContent.value; //注意:data-----------需要自定义 url=baseurl + "/servlet/ListDemo"; //注意:url-----------需要自定义 sendRequest("post",url,data,getResult); } else if (/^[\u4e00-\u9fa5]*$/.test(inputContent.value)) { //检测出是中文 data="type=searchChinese¶m="+inputContent.value; //注意:data-----------需要自定义 url=baseurl + "/servlet/ListDemo"; //注意:url-----------需要自定义 sendRequest("post",url,data,getResult); } } //填写仓库下拉框 function getResult(result) { var data=result; var JData=eval("(" + data + ")"); var maxlength=10; //注释:maxlength保证过多查询结果下只显示10条 if(JData.length<=10) { maxlength=JData.length; } var sub=listobj.childNodes; for (var i =sub.length-1; i>=0 ; i--) { listobj.removeChild(sub[i]); //清空datalist所有的下拉选项 } if(JData.length==0) //没有查询结果 { alert("没有符合条件的结果,请重输"); inputContent.value=""; //清空input输入框的值 return false; } for (var i=0;i 登入後複製
以上是Html5新標籤datalist實作輸入框與後台資料庫資料的動態比對的詳細介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!