我在这个指令中遇到了一些问题;第一个是我看不到列表中的任何项目..然后有时它说ngRepeat有重复的值,然后即使我能够看到一些我无法选择它并把它放在输入上!怎么可能?这是一个掠夺者
http://plnkr.co/edit/vTwOqcN4pm3FgKLYlLu9?p=preview
顺便说一下,这是html代码部分:
<body ng-controller="MainCtrl">
<tags-input ng-model="tags"add-from-autocomplete-only="true">
<auto-complete min-length="1"
source="loadTags($query)"
template="my-custom-template"></auto-complete>
</tags-input>
<p>Model: {{tags}}</p>
<script type="text/ng-template" id="my-custom-template">
<div class="right-panel>
<span ng-bind-html="$highlight($getDisplayText())"></span>
<h1 style="font-size: 15px!important" class="uk-margin-remove">
{{data.name}}
</h1>
</div>
</script>
</body>
这里有角度:
var app = angular.module('plunker', ['ngTagsInput']);
app.controller('MainCtrl', function($scope, $http) {
$scope.tags = [];
$scope.loadTags = function(query) {
return $http.get('tags.json', {
cache: true
}).then(function(data) {
$scope.names = data.data.data;
return $scope.names;
});
};
});
答案 0 :(得分:1)
我已经解决了您的问题并以简单的方式找到了解决方案。我测试了它,它的工作原理。我希望这就是你要找的东西。
Angular脚本文件
var app = angular.module('plunker', ['ngTagsInput']);
app.controller('MainCtrl', function($scope, $http) {
$scope.tags = [];
$scope.names = [];
$scope.loadTags = function() {
return $http.get('tags.json').then(function(response) {
var data = response.data.data.data;
$scope.names = [];
for (var tag in data)
{
$scope.names.push(data[tag].name);
}
return $scope.names;
});
};
});
HTML文件
<tags-input ng-model="tags" add-from-autocomplete-only="true">
<auto-complete min-length="1"
source="loadTags()"
template="my-custom-template"></auto-complete>
</tags-input>
<p>Model: {{tags}}</p>
答案 1 :(得分:0)
您的代码看起来不错。我看到的唯一问题是,在tags.json中,data.data对象应采用{id:idVal,text:nameVal}的形式。也就是说,显示字段名称应为“text”而不是“name”。
答案 2 :(得分:0)
使用这个plunker
http://plnkr.co/edit/QFjUPSUENc8RiqipRT28?p=preview
使用key-property = "id" and display-property="name
删除重复错误,并显示列表