我第一次使用Angular Material。我遇到了自动完成问题。以下是我的模板:
$.ajax({
url: "/search/" + encodeURIComponent("x-men")
}).done(function(data) {console.log(data);});
在ctrl中我有:
<md-autocomplete class="flex"
md-no-cache="true"
md-selected-item="c.receipt"
md-item-text="item.name"
md-search-text="SearchText"
md-items="item in querySearch(SearchText)"
md-floating-label="search">
<md-item-template>
<span><span class="search-result-type">{{item.GEOType}}</span><span md-highlight-text="SearchText">{{item.GEOName+(item.country?' / '+item.country:'')}}</span></span>
</md-item-template>
<md-not-found>No matches found.</md-not-found>
</md-autocomplete>
使用上面的代码,我没有得到任何建议,只显示我未找到的文本,而我的http调用返回一个在控制台中打印的数组。我错过了什么吗?
我在许多地方看到,人们使用了一些自动完成的过滤器,我不认为这是必不可少的。
请告知如何进行上述工作。
答案 0 :(得分:1)
$ http返回promise,md-autocomplete使用相同的promise来显示结果。在你的情况下,你返回的结果,但没有承诺。你的代码应该是
$scope.querySearch = function (query) {
var GeoDataAPIUrl = '/api/TargetSettings/RetrieveCorridorLeverValues';
if (query.length < 5)
return;
else {
var GeoDataSearchUrl = GeoDataAPIUrl + '?' + 'strGeoName=' + query;
var promise = $http.get(GeoDataSearchUrl).then(function (geoAPIResponse) {
console.log("GeoAPIResponse was ", geoAPIResponse);
return geoAPIResponse.data;
},
function (geoAPIError) {
console.log("GeoAPI call failed ", geoAPIError);
});
return promise;
}
};
它现在可以使用了。