2010-03-12 03:18:34 +00:00
<!DOCTYPE html>
< html lang = "en" >
2010-01-20 14:00:14 +00:00
< head >
2010-09-10 02:33:09 +00:00
< meta charset = "utf-8" >
< title > jQuery UI Autocomplete - Combobox< / title >
2010-09-10 02:24:52 +00:00
< link rel = "stylesheet" href = "../../themes/base/jquery.ui.all.css" >
2012-03-22 13:45:22 +00:00
< script src = "../../jquery-1.7.2.js" > < / script >
2010-09-10 02:24:52 +00:00
< script src = "../../ui/jquery.ui.core.js" > < / script >
< script src = "../../ui/jquery.ui.widget.js" > < / script >
< script src = "../../ui/jquery.ui.button.js" > < / script >
< script src = "../../ui/jquery.ui.position.js" > < / script >
2010-12-22 17:31:27 +00:00
< script src = "../../ui/jquery.ui.menu.js" > < / script >
2010-09-10 02:24:52 +00:00
< script src = "../../ui/jquery.ui.autocomplete.js" > < / script >
2010-12-22 17:58:57 +00:00
< script src = "../../ui/jquery.ui.tooltip.js" > < / script >
2010-09-10 02:24:52 +00:00
< link rel = "stylesheet" href = "../demos.css" >
< style >
2011-05-27 12:32:48 +00:00
.ui-button {
margin-left: -1px;
}
.ui-button-icon-only .ui-button-text {
padding: 0.35em;
}
.ui-autocomplete-input {
margin: 0;
padding: 0.4em 0 0.4em 0.45em;
}
2010-03-20 20:57:37 +00:00
< / style >
2010-09-10 02:24:52 +00:00
< script >
2010-07-20 18:20:46 +00:00
(function( $ ) {
$.widget( "ui.combobox", {
2010-01-20 14:00:14 +00:00
_create: function() {
2012-02-12 14:14:36 +00:00
var that = this,
2010-09-10 02:24:52 +00:00
select = this.element.hide(),
2010-07-20 18:49:14 +00:00
selected = select.children( ":selected" ),
value = selected.val() ? selected.text() : "";
2011-05-06 23:40:38 +00:00
function removeIfInvalid(element) {
var value = $( element ).val(),
matcher = new RegExp( "^" + $.ui.autocomplete.escapeRegex( value ) + "$", "i" ),
valid = false;
select.children( "option" ).each(function() {
if ( $( this ).text().match( matcher ) ) {
this.selected = valid = true;
return false;
}
});
if ( !valid ) {
// remove invalid value, as it didn't match anything
$( element )
.val( "" )
.attr( "title", value + " didn't match any item" )
.tooltip( "open" );
select.val( "" );
setTimeout(function() {
input.tooltip( "close" ).attr( "title", "" );
}, 2500 );
input.data( "autocomplete" ).term = "";
return false;
}
}
2010-11-23 13:22:40 +00:00
var input = this.input = $( "< input > " )
2010-07-20 18:20:46 +00:00
.insertAfter( select )
2010-07-20 18:49:14 +00:00
.val( value )
2011-01-11 03:47:30 +00:00
.attr( "title", "" )
2010-01-20 14:00:14 +00:00
.autocomplete({
2010-07-20 18:20:46 +00:00
delay: 0,
minLength: 0,
source: function( request, response ) {
2010-07-20 18:35:54 +00:00
var matcher = new RegExp( $.ui.autocomplete.escapeRegex(request.term), "i" );
2010-07-20 18:20:46 +00:00
response( select.children( "option" ).map(function() {
var text = $( this ).text();
if ( this.value & & ( !request.term || matcher.test(text) ) )
2010-01-20 14:00:14 +00:00
return {
2010-07-20 18:20:46 +00:00
label: text.replace(
new RegExp(
"(?![^&; ]+;)(?!< [^< >]*)(" +
$.ui.autocomplete.escapeRegex(request.term) +
")(?![^< >]*>)(?![^&; ]+;)", "gi"
), "< strong > $1< / strong > " ),
value: text,
option: this
2010-01-20 14:00:14 +00:00
};
2010-07-20 18:20:46 +00:00
}) );
2010-01-20 14:00:14 +00:00
},
2010-07-20 18:20:46 +00:00
select: function( event, ui ) {
ui.item.option.selected = true;
2012-02-12 14:14:36 +00:00
that._trigger( "selected", event, {
2010-07-20 18:20:46 +00:00
item: ui.item.option
});
},
change: function( event, ui ) {
2011-05-06 23:40:38 +00:00
if ( !ui.item )
return removeIfInvalid( this );
2010-07-20 18:20:46 +00:00
}
2010-01-20 14:00:14 +00:00
})
2010-07-20 18:20:46 +00:00
.addClass( "ui-widget ui-widget-content ui-corner-left" );
input.data( "autocomplete" )._renderItem = function( ul, item ) {
2011-05-27 12:32:48 +00:00
return $( "< li > " )
2010-07-19 19:45:30 +00:00
.data( "item.autocomplete", item )
.append( "< a > " + item.label + "< / a > " )
.appendTo( ul );
};
2010-07-20 18:20:46 +00:00
2010-12-16 10:10:30 +00:00
this.button = $( "< button type = 'button' > < / button > " )
2010-07-20 18:20:46 +00:00
.attr( "tabIndex", -1 )
.attr( "title", "Show All Items" )
2011-01-11 03:47:30 +00:00
.tooltip()
2010-07-20 18:20:46 +00:00
.insertAfter( input )
.button({
icons: {
primary: "ui-icon-triangle-1-s"
},
text: false
})
.removeClass( "ui-corner-all" )
.addClass( "ui-corner-right ui-button-icon" )
.click(function() {
// close if already visible
if ( input.autocomplete( "widget" ).is( ":visible" ) ) {
input.autocomplete( "close" );
2011-05-06 23:40:38 +00:00
removeIfInvalid( input );
2010-07-20 18:20:46 +00:00
return;
}
2011-04-04 12:54:09 +00:00
// work around a bug (likely same cause as #5265)
$( this ).blur();
2010-07-20 18:20:46 +00:00
// pass empty string as value to search for, displaying all results
input.autocomplete( "search", "" );
input.focus();
});
2011-01-11 03:47:30 +00:00
input
.tooltip({
position: {
of: this.button
2011-05-10 15:27:55 +00:00
},
tooltipClass: "ui-state-highlight"
});
2010-11-23 13:22:40 +00:00
},
destroy: function() {
this.input.remove();
this.button.remove();
this.element.show();
$.Widget.prototype.destroy.call( this );
2010-01-20 14:00:14 +00:00
}
});
2010-09-10 02:24:52 +00:00
})( jQuery );
2010-07-20 18:20:46 +00:00
2010-01-20 14:00:14 +00:00
$(function() {
2010-09-10 02:24:52 +00:00
$( "#combobox" ).combobox();
$( "#toggle" ).click(function() {
$( "#combobox" ).toggle();
2010-04-08 10:07:45 +00:00
});
2010-01-20 14:00:14 +00:00
});
< / script >
< / head >
< body >
< div class = "demo" >
< div class = "ui-widget" >
< label > Your preferred programming language: < / label >
2010-04-08 10:07:45 +00:00
< select id = "combobox" >
< option value = "" > Select one...< / option >
2010-07-19 18:10:37 +00:00
< option value = "ActionScript" > ActionScript< / option >
< option value = "AppleScript" > AppleScript< / option >
< option value = "Asp" > Asp< / option >
< option value = "BASIC" > BASIC< / option >
< option value = "C" > C< / option >
< option value = "C++" > C++< / option >
< option value = "Clojure" > Clojure< / option >
< option value = "COBOL" > COBOL< / option >
< option value = "ColdFusion" > ColdFusion< / option >
< option value = "Erlang" > Erlang< / option >
< option value = "Fortran" > Fortran< / option >
< option value = "Groovy" > Groovy< / option >
< option value = "Haskell" > Haskell< / option >
< option value = "Java" > Java< / option >
< option value = "JavaScript" > JavaScript< / option >
< option value = "Lisp" > Lisp< / option >
< option value = "Perl" > Perl< / option >
< option value = "PHP" > PHP< / option >
< option value = "Python" > Python< / option >
< option value = "Ruby" > Ruby< / option >
< option value = "Scala" > Scala< / option >
< option value = "Scheme" > Scheme< / option >
2010-01-20 14:00:14 +00:00
< / select >
< / div >
2010-04-08 10:07:45 +00:00
< button id = "toggle" > Show underlying select< / button >
2010-01-20 14:00:14 +00:00
< / div > <!-- End demo -->
2010-09-10 02:24:52 +00:00
2010-01-20 14:00:14 +00:00
< div class = "demo-description" >
2010-09-10 02:24:52 +00:00
< p > A custom widget built by composition of Autocomplete and Button. You can either type something into the field to get filtered suggestions based on your input, or use the button to get the full list of selections.< / p >
< p > The input is read from an existing select-element for progressive enhancement, passed to Autocomplete with a customized source-option.< / p >
2011-02-25 22:09:58 +00:00
< p > This is not a supported or even complete widget. Its purely for demoing what autocomplete can do with a bit of customization. < a href = "http://www.learningjquery.com/2010/06/a-jquery-ui-combobox-under-the-hood" > For a detailed explanation of how the widget works, check out this Learning jQuery article.< / a > < / p >
2010-01-20 14:00:14 +00:00
< / div > <!-- End demo - description -->
< / body >
< / html >