Heim  >  Artikel  >  Java  >  Ajax Java implementiert die Funktion zur automatischen Vervollständigung

Ajax Java implementiert die Funktion zur automatischen Vervollständigung

高洛峰
高洛峰Original
2017-01-12 09:24:571382Durchsuche

Wir alle wissen, dass Baidu die Verwendung von Ajax empfiehlt. Es ist nicht einfach, es schnell, stabil, reproduzierbar und portabel zu machen. Nach langer Online-Suche sind viele von ihnen ASP oder PHP, und einige verwenden JQuery, aber es gibt zu wenige erläuternde Dokumente. Es ist besser, sie selbst zu schreiben, als Zeit mit Recherche zu verbringen. Basierend auf den Informationen, die ein PDF-Dokument lieferte, dauerte es einen halben Tag, um es endlich zu erreichen. Teilen Sie es hier mit allen.
Das Prinzip-Flussdiagramm lautet wie folgt:

ajax java 实现自动完成功能

Das Flussdiagramm ist sehr klar, es gibt nichts zu sagen, hier ist der Code.
Javascript-Code:

var xmlHttpRequest; 
var table; 
var tbody; 
var div; 
var input; 
var curIndex; 
var size; 
var r_userId; 
function createXMLHttpRequest(){ 
if(window.ActiveXObject){ 
xmlHttpRequest = new ActiveXObject("Microsoft.XMLHTTP"); 
}else if(window.XMLHttpRequest){ 
xmlHttpRequest = new XMLHttpRequest(); 
} 
} 
//发送请求 
function findNames(){ 
if(event.keyCode==38||event.keyCode==40){ 
}else{ 
if(input.value.length>0){ 
createXMLHttpRequest(); 
var url = encodeURI(encodeURI("/jforum.html?module=posts&action=findDept&names="+input.value)); 
xmlHttpRequest.open("GET",url,true); 
xmlHttpRequest.onreadystatechange=processMatchResponse; 
xmlHttpRequest.send(null); 
}else{ 
clearNames(); 
} 
} 

} 
function processMatchResponse(){ 
if(xmlHttpRequest.readyState==4){ 
if(xmlHttpRequest.status==200){ 
//alert(xmlHttpRequest.status); 
//var id = xmlHttpRequest.responseXML.getElementsByTagName("id"); 
var dept = xmlHttpRequest.responseXML.getElementsByTagName("dept"); 
var id = xmlHttpRequest.responseXML.getElementsByTagName("id"); 

setNames(dept,id); 

}else{ 
window.alert("您所请求的页面有异常!"); 
} 
} 
} 
function setNames(depts,ids){ 
clearNames(); 
size = depts.length; 
if(size>0){ 
div.style.visibility = "visible"; 
var row,col1,col2,span; 

for(var i = 0;i < size;i++){ 
row = document.createElement("tr"); 
col1 = document.createElement("td"); 
col1.innerText = depts[i].firstChild.data; 
col2 = document.createElement("td"); 
col2.setAttribute("align","right"); 
col2.setAttribute("id","col2"); 
col2.setAttribute("width","5%"); 
span = document.createElement("span"); 
span.innerText = ids[i].firstChild.data; 
span.style.display = "none"; 
col2.appendChild(span); 


row.appendChild(col1); 
row.appendChild(col2); 
row.onmouseout = function(){ 
this.className = &#39;mouseOut&#39;; 
} 
row.onmouseover = function(){ 
clearSelected(); 
this.className = &#39;mouseOver&#39;; 
curIndex = this.rowIndex; 
} 
row.onclick = function(){ 
input.value = this.cells[0].innerText; 
r_userId.value = table.rows[curIndex].cells[1].innerText; 
clearNames(); 
}; 
tbody.appendChild(row); 
} 
row = document.createElement("tr"); 
col2 = document.createElement("td"); 
col1 = document.createElement("td"); 
col2.setAttribute("align","right"); 
link = document.createElement("a"); 
link.href = "javascript:clearNames();"; 
link.innerHTML = "关闭"; 
col1.appendChild(link); 
row.appendChild(col1); 
row.appendChild(col2); 
tbody.appendChild(row); 
} 
} 
function setPosition(){ 
input = document.getElementById("names"); 
r_userId = document.getElementById("r_userId"); 
table = document.getElementById("table"); 
div = document.getElementById("div"); 
tbody = document.getElementById("tbody"); 

div.style.width = input.offsetWidth-2; 
div.style.border = "gray 1px solid"; 
div.style.left = getLeft(input); 
div.style.top = getTop(input)+input.offsetHeight+6; 

curIndex = -1; 
input.focus();//div.style.left+","+div.style.top 
} 
function clearNames(){ 
var ind = tbody.childNodes.length; 
for(i=ind-1;i>=0;i--){ 
tbody.removeChild(tbody.childNodes[i]); 
} 
div.style.visibility="hidden"; 
curIndex = -1; 
} 
function clearSelected(){ 
var ind = tbody.childNodes.length; 
for(var i = ind-1;i>=0;i--){ 
tbody.childNodes[i].className = "mouseOut"; 
} 
} 
function keyDown(){ 
if(div.style.visibility=="visible"){ 
if(event.keyCode ==38){ 
if(curIndex>=0){ 
table.rows[curIndex].className=&#39;mouseOut&#39;; 
curIndex = curIndex-1; 
if(curIndex>=0){ 
table.rows[curIndex].className = &#39;mouseOver&#39;; 
input.value = table.rows[curIndex].cells[0].innerText; 
r_userId.value = table.rows[curIndex].cells[1].innerText; 
} 
} 
} 
if(event.keyCode==40){ 
if(curIndex<size-1){ 
if(curIndex>=0){ 
table.rows[curIndex].className = &#39;mouseOut&#39;; 
} 
curIndex = curIndex+1; 
table.rows[curIndex].className = &#39;mouseOver&#39;; 
input.value = table.rows[curIndex].cells[0].innerText; 
r_userId.value = table.rows[curIndex].cells[1].innerText; 
}else{ 
table.rows[curIndex].className = &#39;mouseOut&#39;; 
curIndex = -1; 
} 
} 
} 
} 
//获取元素的纵坐标 
function getTop(e){ 
var offset=e.offsetTop; 
if(e.offsetParent!=null) offset+=getTop(e.offsetParent); 
return offset; 
} 
//获取元素的横坐标 
function getLeft(e){ 
var offset=e.offsetLeft; 
if(e.offsetParent!=null) offset+=getLeft(e.offsetParent); 
return offset; 
}

Es gibt zu viel Code und es ist etwas chaotisch. JQuery wird nicht verwendet, aber es zeigt besser die Fähigkeiten des Autors. Die folgenden Punkte werden erläutert:
1. setPosition() wird zum Initialisieren verschiedener global erforderlicher Variablen verwendet und muss daher zuerst aufgerufen werden, wenn die Seite geladen wird, z. B. in der Onload-Methode des Körpers oder anderen Methoden.
2. findNames() ist eine Methode zum Betrieb von Ajax. Jeder, der mit Ajax vertraut ist, kann verstehen, dass das Wichtigste darin besteht, die Parameter encodeURI() neu zu kodieren und entsprechend im Hintergrund zu dekodieren.
3. ProcessMatchResponse() ist eine Rückruffunktion, die zur Verarbeitung der vom Hintergrund zurückgegebenen Daten verwendet wird. Dies wird von setNames() verarbeitet.
4. SetNames verwendet den Tabellenmodus, um den Inhalt der Eingabeaufforderung anzuzeigen. Hier finden Sie weitere Informationen zu JS und Node.
5. Die Methoden getTop und getLeft dienen dazu, die absolute Position des Textfelds relativ zur oberen linken Ecke des Browsers zu ermitteln.
Der Java-Hintergrundcode lautet wie folgt:

public void findDept() throws IOException{ 
String partDeptName = this.request.getParameter("names"); 
partDeptName = java.net.URLDecoder.decode(partDeptName, "UTF-8"); 
Map<String,String> userMap = DataAccessDriver.getInstance().newUserDAO().getDeptByPart("%" + partDeptName + "%"); 

this.response.setContentType("text/xml;charset=UTF-8"); 
this.response.setHeader("Cache-Control", "no-cache"); 


ServletOutputStream pw = this.response.getOutputStream(); 
OutputStreamWriter out = new OutputStreamWriter(pw,"UTF-8"); 

out.write("<res>"); 
Iterator<Map.Entry<String, String>> it = userMap.entrySet().iterator(); 
while(it.hasNext()){ 
Map.Entry<String, String> entry=(Map.Entry<String,String>)it.next(); 
out.write("<id>"+entry.getKey()+"</id>"); 
out.write("<dept>"+entry.getValue()+"</dept>"); 
} 
out.write("</res>"); 

out.flush(); 
out.close(); 

}

Wichtige Punkte:
1. Achten Sie auf die Dekodierung der Parameter.
2. Fuzzy-Matching wird je nach Situation bei der Abfrage durchgeführt.
3. Die zurückgegebenen Daten liegen im XML-Format oder im JSON-Format vor.
4. Hier wird die Rückgabemethode verwendet

ServletOutputStream pw = this.response.getOutputStream(); 
OutputStreamWriter out = new OutputStreamWriter(pw,"UTF-8");

Ein solcher Ablauf ist durch das System-Framework begrenzt, Sie können PrintWriter out = Response.getWriter(); Natürlich aus Die Methode ist println (), die je nach Situation Ihres eigenen Frameworks auch flexibel geändert werden kann.

Weitere Artikel zur Implementierung der automatischen Vervollständigungsfunktion durch Ajax Java finden Sie auf der chinesischen PHP-Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn