Struts2 + jQuery autocompletado
-
18-09-2019 - |
Pregunta
He utilizado el jQuery terminación automática para mi aplicación Struts2" nofollow noreferrer Struts2 .
práticamente, mi acción hizo una lista de cadenas que utilizan jQuery. Esta es la secuencia de comandos:
$().ready(function() {
$("#tag").autocomplete("/myAction/Action", {
multiple : true,
autoFill : true,
minChars:1
});
});
Durante tecleando aparece el cuadro con las sugerencias. El problema es que la caja render otro valor, exactamente hacer que el código de mis JSP (enlaces a CSS para el plug-in de autocompletar).
¿Cómo puedo solucionar esto?
Esta es mi JSP:
<html>
<head>
<script src="<%=request.getContextPath()%>/scripts/jquery-latest.js"></script>
<link rel="stylesheet" href="<%=request.getContextPath()%>/scripts/main.css" type="text/css" />
<link rel="stylesheet" href="<%=request.getContextPath()%>/scripts/jquery.autocomplete.css" type="text/css" />
<script type="text/javascript" src="<%=request.getContextPath()%>scripts/jquery.bgiframe.min.js"></script>
<script type="text/javascript" src="/<%=request.getContextPath()%>/query.dimensions.js"></script>
<script type="text/javascript" src="<%=request.getContextPath()%>/scripts/jquery.autocomplete.js"></script>
<script type="text/javascript">
$().ready(function() {
$("#tag").autocomplete("/myAction/Action", {
multiple : true,
autoFill : true,
minChars:1
});
});
</script>
</head>
<body>
<s:form action="Action" theme="simple">
<s:iterator value="elencoMateriali" var="asd">
<s:property value="#asd" escape="false"/>
</s:iterator>
<s:textfield id="tag" name="tagField" label="tag" />
</s:form>
</body>
Solución 2
<%@ taglib prefix="s" uri="/struts-tags" %>
<%@ taglib prefix="sx" uri="/struts-dojo-tags" %>
<s:form action="ActionJson" theme="simple">
<s:url id="elencoFuffa" action="ActionJSON"/>
<sx:autocompleter id="autocompleter" name="materiale" loadOnTextChange="true" preload="false" href="%{elencoFuffa}" size="24" loadMinimumCount="1" showDownArrow="false" cssClass="dropDown" onchange="submit();"/>
<s:submit value="Prosegui"/>
<s:property value="luoghiSmaltimento"/>
</s:form>
Ahora, la Acción:
public class Action extends ActionSupport {
private String materiale;
private String luoghi;
private List<String> elencoMateriali;
private Map<String, String> json;
public String execute() throws Exception {
System.out.println("------------------" + materiale);
return SUCCESS;
}
public String getMateriali() throws Exception {
MaterialiDAO dao = new MaterialiDAO();
List<Materiali> toResult = new ArrayList<Materiali>();
toResult = dao.findAll();
elencoMateriali = new ArrayList<String>();
Iterator i = toResult.iterator();
while (i.hasNext()) {
Materiali m = (Materiali) i.next();
elencoMateriali.add(m.getValueNomemateriale());
}
return SUCCESS;
}
public String getJson() throws Exception {
json = new HashMap<String, String>();
if (materiale != null && materiale.length() > 0) {
MaterialiDAO dao = new MaterialiDAO();
List<Materiali> materiali = dao.findByLikeValue(materiale);
for (Materiali m : materiali) {
json.put(m.getValueNomemateriale(), "" + m.getIdMateriali());
}
}
return SUCCESS;
}
public String trovaLuogo() throws Exception {
LuoghismalDAO daoL = new LuoghismalDAO();
MaterialiDAO daoM = new MaterialiDAO();
Materiali m = daoM.findByMaterialiName(materiale);
if (m != null) {
luoghi = m.getLuoghismal().getValueDescrluogo();
return SUCCESS;
} else {
luoghi = "-- Scegliere un materiale --";
return SUCCESS;
}
}
/* Getters and setters */
Al final la struts.xml
<action name="ActionJSON" class="it.action.Action"
method="getJson">
<result type="json">
<param name="root">json</param>
</result>
</action>
Otros consejos
Creo que es demasiado tarde para una respuesta, pero los probles todavía está quedando en Struts2. He hecho algunas modificaciones para resolver tal problema:
-
Copie el archivo jquery.struts2.js en que JS camino.
-
Editar el fil jquery.struts2.js y buscar el éxito: function (datos) "en el mango del Widget Autocompleter, y reemplazar la función para la siguiente:
success: function(data) { var x = 0; if (data[o.list] !== null) { var isMap = false; if (!$.isArray(data[o.list])) { isMap = true; } var result = []; $.each(data[o.list], function(j, val) { if (isMap) { result.push({ label: val.replace( new RegExp( "(?![^&;]+;)(?!<[^<>]*)(" + $.ui.autocomplete.escapeRegex(request.term) + ")(?![^<>]*>)(?![^&;]+;)", "gi" ), "<strong>$1</strong>" ), value: val, id: j }); } else { if (o.listkey !== undefined && o.listvalue !== undefined) { result.push({ label: val[o.listvalue].replace( new RegExp( "(?![^&;]+;)(?!<[^<>]*)(" + $.ui.autocomplete.escapeRegex(request.term) + ")(?![^<>]*>)(?![^&;]+;)", "gi" ), "<strong>$1</strong>" ), value: val[o.listvalue], id: val[o.listkey] }); } else { result.push({ label: data[o.list][x].replace( new RegExp( "(?![^&;]+;)(?!<[^<>]*)(" + $.ui.autocomplete.escapeRegex(request.term) + ")(?![^<>]*>)(?![^&;]+;)", "gi" ), "<strong>$1</strong>" ), value: data[o.list][x], id: data[o.list][x] }); } } x++; }); response(result); }
}
-
Ahora, si se suscribe un método onSelectTopics en su código JSP, tendrá un nuevo elemento item.id disponibles, lo que puede establecer el valor de ID en un oculto o lo que quiera.
Ahora, su Autocompleter mostrar una lista con la palabra fuerte, llena la entrada con la selección, y mantains el ID en una variable se puede coger.
Recuerde agregar el js modificados en la sección de encabezado incluir.