蝙蝠岛资源网 Design By www.hbtsch.com
最近项目中涉及到一个小功能,客户在选择供应商时,由于供应商数目较多(大概3000个左右),因此直接生成下拉框显然不现实,所以就更换解决方案,打算借助HTML5新增的标签datalist来实现输入中文/拼音首字母时,自动进入数据库模糊查询,并返回相应的结果,生成datalist,由于在输入框中的输入内容发生变化时,datalist会自动触发下拉框,所以使用起来比select更便捷。前端部分代码如下:
Html Code:
<!DOCTYPE html>
<html lang="en">
<head id="head">
<title>库存下拉框测试</title>
<meta charset="utf-8">
<meta content="IE=edge,chrome=1" http-equiv="X-UA-Compatible">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="description" content="">
<meta name="author" content="">
<script src="../../Common/content/jquery-1.7.2.min.js"type="text/javascript"></script>
<script src="../../Common/pages/include.js" class="include" type="text/javascript"></script>
<script src="../../Common/js/AjaxJson.js" type="text/javascript"></script>
<script src="../../Common/js/Setting.js" type="text/javascript"></script>
<script src="../../Common/js/Paging.js" type="text/javascript"></script>
<script src="../../Js/warehouseManage/testyy.js" type="text/javascript"></script>
</head>
<body class="">
<!--<![endif]-->
<div class="navbar"></div>
<div class="sidebar-nav"></div>
<div class="content">
<div class="header"><h1 id="ADU" class="page-title">下拉框测试</h1></div>
<div class="container-fluid">
<div class="row-fluid">
<!-- --------------------------多条件查询--------------------------------------------- -->
<div class="well" id="searchDemo">
<p>测试数据(默认均为d00001):<br> 昆山市大陆配件有限公司 ksdlpjyxgs <br>
亿真企业有限公司 yzqyyxgs <br>
泰州市安誊轴皮厂(集团厂) tzsatzpc(jtc)
</p>
</div>
按 供应商名动态匹配(中文或者拼音均可):
<input list="bro" id="name" oninput="this.value=this.value.replace(/^ +| +$/g,'');search('name','bro','name')" >
<datalist id="bro"></datalist>
</div>
</div>
</div>
</body>
<!-- -----------------------footer-------------------------- -->
<footer class="foot"></footer>
</html>
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<maxlength;i++)
{
var obj=document.createElement("option");
var indexobj=JData[i];
if(/^[a-zA-Z]*$/.test(inputContent.value))
{
obj.value=indexobj[requestItem];
obj.innerHTML=inputContent.value;
}
if (/^[\u4e00-\u9fa5]*$/.test(inputContent.value))
{
obj.value=indexobj[requestItem];
}
listobj.appendChild(obj);
}
var suffix=document.createElement("option");
suffix.value=" ";
suffix.innerHTML="输入更多有关"+inputContent.value+"的信息";
listobj.appendChild(suffix);
return false;
}
以上所述是小编给大家介绍的Html5新标签datalist实现输入框与后台数据库数据的动态匹配,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
蝙蝠岛资源网 Design By www.hbtsch.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
蝙蝠岛资源网 Design By www.hbtsch.com
暂无Html5新标签datalist实现输入框与后台数据库数据的动态匹配的评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2025年11月08日
2025年11月08日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]