1 | <!DOCTYPE html>
|
---|
2 | <html lang="en">
|
---|
3 | <head>
|
---|
4 | <meta charset="utf-8">
|
---|
5 | <title>jQuery UI Autocomplete - XML data parsed once</title>
|
---|
6 | <link rel="stylesheet" href="../../themes/base/jquery.ui.all.css">
|
---|
7 | <script src="../../jquery-1.6.2.js"></script>
|
---|
8 | <script src="../../ui/jquery.ui.core.js"></script>
|
---|
9 | <script src="../../ui/jquery.ui.widget.js"></script>
|
---|
10 | <script src="../../ui/jquery.ui.position.js"></script>
|
---|
11 | <script src="../../ui/jquery.ui.autocomplete.js"></script>
|
---|
12 | <link rel="stylesheet" href="../demos.css">
|
---|
13 | <style>
|
---|
14 | .ui-autocomplete-loading { background: white url('images/ui-anim_basic_16x16.gif') right center no-repeat; }
|
---|
15 | </style>
|
---|
16 | <script>
|
---|
17 | $(function() {
|
---|
18 | function log( message ) {
|
---|
19 | $( "<div/>" ).text( message ).prependTo( "#log" );
|
---|
20 | $( "#log" ).scrollTop( 0 );
|
---|
21 | }
|
---|
22 |
|
---|
23 | $.ajax({
|
---|
24 | url: "london.xml",
|
---|
25 | dataType: "xml",
|
---|
26 | success: function( xmlResponse ) {
|
---|
27 | var data = $( "geoname", xmlResponse ).map(function() {
|
---|
28 | return {
|
---|
29 | value: $( "name", this ).text() + ", " +
|
---|
30 | ( $.trim( $( "countryName", this ).text() ) || "(unknown country)" ),
|
---|
31 | id: $( "geonameId", this ).text()
|
---|
32 | };
|
---|
33 | }).get();
|
---|
34 | $( "#birds" ).autocomplete({
|
---|
35 | source: data,
|
---|
36 | minLength: 0,
|
---|
37 | select: function( event, ui ) {
|
---|
38 | log( ui.item ?
|
---|
39 | "Selected: " + ui.item.value + ", geonameId: " + ui.item.id :
|
---|
40 | "Nothing selected, input was " + this.value );
|
---|
41 | }
|
---|
42 | });
|
---|
43 | }
|
---|
44 | });
|
---|
45 | });
|
---|
46 | </script>
|
---|
47 | </head>
|
---|
48 | <body>
|
---|
49 |
|
---|
50 | <div class="demo">
|
---|
51 |
|
---|
52 | <div class="ui-widget">
|
---|
53 | <label for="birds">London matches: </label>
|
---|
54 | <input id="birds" />
|
---|
55 | </div>
|
---|
56 |
|
---|
57 | <div class="ui-widget" style="margin-top:2em; font-family:Arial">
|
---|
58 | Result:
|
---|
59 | <div id="log" style="height: 200px; width: 300px; overflow: auto;" class="ui-widget-content"></div>
|
---|
60 | </div>
|
---|
61 |
|
---|
62 | </div><!-- End demo -->
|
---|
63 |
|
---|
64 |
|
---|
65 |
|
---|
66 | <div class="demo-description">
|
---|
67 | <p>This demo shows how to retrieve some XML data, parse it using jQuery's methods, then provide it to the autocomplete as the datasource.</p>
|
---|
68 | <p>This should also serve as a reference on how to parse a remote XML datasource - the parsing would just happen for each request within the source-callback.</p>
|
---|
69 | </div><!-- End demo-description -->
|
---|
70 |
|
---|
71 | </body>
|
---|
72 | </html>
|
---|