octobre
2009
Récemment, pour un projet, il a fallu ajouter une auto-complétion a un champ, et un stockage de l’Id dans un champ caché.
Pour ca, avec JQuery, il suffit de faire, dans le fichier .aspx :
$(document).ready(function() {
$("#<%=tbUser.ClientID%>").autocomplete("ComboUserService.aspx",
{
matchCase:true,
selectOnly:1,
minChars:2,
lineSeparator: ‘\n’,
cellSeparator: ‘|’,
autoFill:false,
onItemSelect: function(li) {
if (li.extra) {
$("#<%=hidUserUID.ClientID%>").val(li.extra<0>);
}
}
});
});
<div>
<asp:TextBox ID="tbUser" runat="server" SkinID="UsualTextBox"></asp:TextBox>
<asp:HiddenField ID="hidUserUID" runat="server" />
</div>
NB : le $("#<%= tbUser.ClientID %>"), ca veut dire, écrit l’id cote client de tbUser, de façon a ce que je puisse utiliser le sélecteur # de JQuery, qui sélectionne un élément du DOM par son ID ;), $ est l’alias de la classe JQuery. Pour plus d’infos, une introduction peut être trouvée ici
Ensuite, il faut ajouter dans le répertoire App_Code un fichier AjaxHandler du genre :
public class AjaxHandler : IHttpHandler {
public string _inputValue;
public void ProcessRequest(HttpContext context) {
context.Response.Cache.SetCacheability(HttpCacheability.NoCache);
context.Response.ContentType = "text/plain";
_inputValue = context.Request.QueryString<"q">;
string result = ObjectFactory.GetInstance<IUserService>()
.GetUsersForAutocompletion(_inputValue);
context.Response.Write(result);
}
public bool IsReusable {
get { return false; }
}
}
Avec, dans le web.config, une configuration du AjaxHandler du genre:
Et du coup, si ma méthode GetUsersForAutocompletion renvoie un résultat au format :
User1|Id1;User2|Id2;…;User3|Id3
J’obtiens une jolie auto complétion en, quoi, dix minutes de travail et en ajoutant juste 30ko de JavaScript pour la bibliothèque de JQuery et trois fois rien pour les échanges Ajax…en théorie…
Pourquoi en théorie ? Parce que si j’initialise le champ dans le code-behind, des que j’attache l’auto complétion a mon textbox, ce même textbox est vide…moyen, l’effet, pour le client
Moralité, plutôt que de chercher une solution propre (mais promis, chercher la solution propre, c’est pour "dés qu’il n’y a plus le feu), le code a été remanié comme ca :
var tmp = $("#<%=tbUser.ClientID%>").val();
$("#<%=tbUser.ClientID%>").autocomplete("ComboUserService.aspx",
{
matchCase:true,
selectOnly:1,
lineSeparator: ‘\n’,
cellSeparator: ‘|’,
autoFill:false,
onItemSelect: function(li) {
if (li.extra) {
$("#<%=hidUserUID.ClientID%>").val(li.extra[0]);
}
}
});
var tmp = $("#<%=tbUser.ClientID%>").val();
});
Et depuis, tout marche bien :D..ceci dit, si quelqu’un a une idée de l’origine du problème, ca m’aiderait bien (d’autant qu’en dehors de ca, JQuery, c’est le panard)
Articles récents
Archives
- janvier 2014
- septembre 2013
- août 2013
- mai 2013
- avril 2013
- janvier 2013
- août 2012
- juin 2012
- mai 2012
- avril 2012
- mars 2012
- novembre 2011
- septembre 2011
- août 2011
- juillet 2011
- juin 2011
- mai 2011
- avril 2011
- février 2011
- janvier 2011
- novembre 2010
- octobre 2010
- septembre 2010
- août 2010
- juillet 2010
- juin 2010
- mai 2010
- avril 2010
- mars 2010
- février 2010
- janvier 2010
- décembre 2009
- novembre 2009
- octobre 2009
- septembre 2009
- août 2009
- juillet 2009
- juin 2009
- mai 2009
- avril 2009
- mars 2009
- février 2009
- janvier 2009