datalist输入框与后台数据库数据的动态匹配

ID:8772 / 打印

这次给大家带来datalist输入框与后台数据库数据的动态匹配,datalist输入框与后台数据库数据的动态匹配的注意事项有哪些,下面就是实战案例,一起来看一下。

最近项目中涉及到一个小功能,客户在选择供应商时,由于供应商数目较多(大概3000个左右),因此直接生成下拉框显然不现实,所以就更换解决方案,打算借助HTML5新增的标签datalist来实现输入中文/拼音首字母时,自动进入数据库模糊查询,并返回相应的结果,生成datalist,由于在输入框中的输入内容发生变化时,datalist会自动触发下拉框,所以使用起来比select更便捷。前端部分代码如下:

Html Code:

nbsp;html&gt;               <title>库存下拉框测试</title>       <meta>       <meta>       <meta>       <meta>       <meta>       <script></script>       <script></script>       <script></script>       <script></script>       <script></script>       <script></script>                  <!--<![endif]-->       <p></p>       <p></p>       <p>           </p><p></p><h1>下拉框测试</h1>           <p>               </p><p>                   <!-- --------------------------多条件查询--------------------------------------------- -->                   </p><p>                   </p><p>测试数据(默认均为d00001):<br>    昆山市大陆配件有限公司     ksdlpjyxgs <br>                               亿真企业有限公司                        yzqyyxgs        <br>                               泰州市安誊轴皮厂(集团厂)   tzsatzpc(jtc)                   </p>                                            按 供应商名动态匹配(中文或者拼音均可):                       <input>                       <datalist></datalist>                                                                <!-- -----------------------footer-------------------------- -->                   <footer></footer>   

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&gt;0)           {               for (var i =sub.length-1; i&gt;=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=0 ; i--)        {           listobj.removeChild(sub[i]);    //清空datalist所有的下拉选项        }       if(JData.length==0)  //没有查询结果       {           alert("没有符合条件的结果,请重输");           inputContent.value="";    //清空input输入框的值           return false;       }       for (var i=0;i<maxlength><p>相信看了本文案例你已经掌握了方法,更多精彩请关注24分享网其它相关文章!</p> <p>推荐阅读:</p> <p style="text-align: left;"><a href="http://www.php.cn/html5-tutorial-390095.html" target="_blank">怎样使用phonegap查找联系人</a><br></p> <p style="text-align: left;"><a href="http://www.php.cn/html5-tutorial-390091.html" target="_blank">phonegap的常用事件总结</a><br></p></maxlength>
上一篇: H5文件异步上传
下一篇: indexeddb数据库的使用详解

作者:admin @ 24资源网   2024-09-18

本站所有软件、源码、文章均有网友提供,如有侵权联系308410122@qq.com

与本文相关文章

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。