2013-03-27 4 views
9

Ich habe den folgenden Code. Es erzeugt keine js-Fehler. Die automatische Vervollständigung kann keine Ergebnisse anzeigen:jquery Autocomplete renderItem

$(function() { 
    $.ajax({ 
    url: "data.xml", 
    dataType: "xml", 
    cache: false, 
    success: function (xmlResponse) { 
     var data_results = $("Entry", xmlResponse).map(function() { 
      return { 
       var1: $.trim($("Partno", this).text()), 
       var2: $.trim($("Description", this).text()), 
       var3: $.trim($("SapCode", this).text()), 
       var4: $("Title", this).text(), 
       var5: $.trim($("File", this).text()), 
       var6: $.trim($("ItemID", this).text()) 
      }; 
     }).get(); 

     $("#searchresults").autocomplete({ 
      source: data_results, 
      minLength: 3, 
      select: function (event, ui) { 
       ... 
      } 
     }).data("autocomplete")._renderItem = function(ul, item) { 
       return $("<li></li>").data("item.autocomplete", item) 
        .append("<a>" + item.var1 + "<br>" + item.var2 + "</a>") 
        .appendTo(ul); 
     }; 

    } 
}); 

Irgendwelche Ideen, was ich vermisse? Danke im Voraus.

Antwort

5

standardmäßig die automatische Vervollständigung erwartet Ihr Quell-Array-Objekte enthalten entweder mit einer label Eigenschaft, eine value Eigenschaft, oder beides.

, die mit im Auge haben Sie zwei Möglichkeiten:

  1. ein Etikett oder Wert-Eigenschaft auf Ihre Quellobjekte hinzufügen, wenn Sie das Array aus Ihrem AJAX-Aufruf verarbeiten:

    var data_results = $("Entry", xmlResponse).map(function() { 
        return { 
         var1: $.trim($("Partno", this).text()), 
         var2: $.trim($("Description", this).text()), 
         var3: $.trim($("SapCode", this).text()), 
         var4: $("Title", this).text(), 
         var5: $.trim($("File", this).text()), 
         var6: $.trim($("ItemID", this).text()), 
         value: $.trim($("Description", this).text()) 
        }; 
    }).get(); 
    

    The value Sie assign wird auf focus, select verwendet und danach gesucht.

  2. Ändern der source Funktion benutzerdefinierte Filterlogik auszuführen:

    $("#searchresults").autocomplete({ 
        source: function (request, response) { 
         var matcher = new RegExp($.ui.autocomplete.escapeRegex(request.term), "i"); 
    
         response($.grep(data, function (value) { 
          return matcher.test(value.var1) || 
            matcher.test(value.var2); 
          /* etc., continue with whatever parts of the object you want */ 
         })); 
        }, 
        minLength: 3, 
        select: function (event, ui) { 
         event.preventDefault(); 
         this.value = ui.var1 + ui.var2; 
        }, 
        focus: function (event, ui) { 
         event.preventDefault(); 
         this.value = ui.var1 + ui.var2; 
        } 
    }).data("autocomplete")._renderItem = function(ul, item) { 
         return $("<li></li>").data("item.autocomplete", item) 
          .append("<a>" + item.var1 + "<br>" + item.var2 + "</a>") 
          .appendTo(ul); 
    }; 
    

    Beachten Sie, dass mit dieser Strategie Sie benutzerdefinierte select und focus Logik zu implementieren.