jQuery UI - Autocomplete - Custom style?
Solution 1
It seems like you have some extra code (ajax call) for the autocomplete that it may not need. But, you can just swap out the special characters that jquery puts in to escape the html in the 'open' event of the autocomplete.
$("#autocomplete_field").autocomplete({
source: "autocomplete.php",
minLength: 2,
open: function(event, ui){
$("ul.ui-autocomplete li a").each(function(){
var htmlString = $(this).html().replace(/</g, '<');
htmlString = htmlString.replace(/>/g, '>');
$(this).html(htmlString);
});
}
});
Full example http://www.jensbits.com/2011/03/03/jquery-autocomplete-with-html-in-dropdown-selection-menu/.
And, if you are using perl in the autcomplete, http://www.jensbits.com/2011/05/09/jquery-ui-autocomplete-widget-with-perl-and-mysql/ is an example for that.
Solution 2
Instead of Success event, use _renderItem event.
Live implementation at Vroom. Type airport, you shall notice an image at the left.
NOTE: _renderItem
below has some complex calculation. Don't go by that, just utilize the idea.
$("#myInput")
.autocomplete({
minLength: 0,
delay: 10,
source: function (req, responseFn) {
//Your ajax call here returning only responseFn Array having item.id and item.id
},
select: function (event, ui) {
//action upon selecting an item
return false;
}
})
.data("autocomplete")
._renderItem = function (ul, item) {
return $("<li></li>")
.data("item.autocomplete", item)
.append("<a><span class='airoplane'>" + (item[0] + (item[2] == "" ? "" : ", " + item[2]) + (item[1] == "" ? "" : " (" + item[1] + ")")).replace(new RegExp("(?![^&;]+;)(?!<[^<>]*)(" + $.ui.autocomplete.escapeRegex(this.term).replace(/([\^\$\(\)\[\]\{\}\*\.\+\?\|\\])/gi, "\\$1") + ")(?![^<>]*>)(?![^&;]+;)", "gi"), "<span class='highlight'>$1</span>") + "</span></a>")
.appendTo(ul);
};
Raoul
Updated on June 14, 2022Comments
-
Raoul almost 2 years
I'm using the following code and it's working, getting values back etc, but the
<b> and <br>
tags show up as text rather than get rendered. I'd like theitem.id
anditem.label
to be on different lines, if possible theitem.id
bold:$( "#predictSearch" ).autocomplete({ source: function( request, response ) { $.ajax({ url: "index.pl", dataType: "json", data: { term: request.term }, success: function( data ) { response( $.map( data.items, function( item ) { return { label: '<B>' + item.id + '</B><br>' + item.label, value: item.id } })); } }); }, minLength: 2 });
-
Raoul about 13 yearsThank you Jen, this makes a lot of sense.
-
iMatoria about 13 yearsI am not sure, but i think this must be having performance issue. Open function shall be called each time user function inside the textbox and start search. Instead, _renderItem function could be used. Otherwise, its nice solution.
-
Raoul about 13 yearsRegarding the perl example rather than print "Content-type: text/html \n\n"; I tend to print $query->header();, and use DBI place holders for SQL injection prevention. Thanks again
-
jk. about 13 years@Raoul Thanks for the tip on the DBI placeholders. I updated my code.
-
jk. about 13 years@iMatoria Doesn't renderItem fire every time the user starts a search as well. I am not sure myself and will look into it.