HTML5変更により、中国語/ピンインの最初の文字を入力すると自動的にデータベースのファジークエリに入り、対応する結果を返してデータリストを生成することを実現するためにタグデータリストを追加しました入力ボックスに入力内容を入力すると、データリストが自動的にドロップダウン ボックスをトリガーします。このソリューションは非常に優れています。必要な方は、この記事を参照してください。最近のプロジェクトには小さな機能が含まれており、顧客がサプライヤーを選択する際、供給の都合上、商材の数が約
3000 であるため、ドロップダウン ボックスを直接生成するのは明らかに非現実的です。このソリューションでは、HTML5 の新しいタグ データリストを使用して、中国語/ピンインの最初の文字を入力するとデータベースに自動的に入力し、データリストが自動的にトリガーされてデータリストが生成されるようにする予定です。入力ボックスの入力内容が変わる場合は、選択よりも使用すると便利です。フロントエンド コードは次のとおりです: Html コード:
库存下拉框测试
下拉框测试
测试数据(默认均为d00001):
按 供应商名动态匹配(中文或者拼音均可):
昆山市大陆配件有限公司 ksdlpjyxgs
亿真企业有限公司 yzqyyxgs
泰州市安誊轴皮厂(集团厂) tzsatzpc(jtc)
JavaScript コード:
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の新しいタグデータリストの詳細な紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。