![](/img/trans.png)
[英]Getting Error: [ngRepeat:dupes] in ng-repeat using angular.js
[英]Getting error in ng-repeat using angular.js
在Angular.js中使用ng-repeat時出現以下錯誤。
錯誤:
Error: [ngRepeat:dupes] http://errors.angularjs.org/1.4.6/ngRepeat/dupes?p0=ses%20in%20sectionData&p1=string%3Al&p2=l
at Error (native)
at http://oditek.in/Gofasto/js/angularjs.js:6:416
at http://oditek.in/Gofasto/js/angularjs.js:279:39
at Object.fn (http://oditek.in/Gofasto/js/angularjs.js:129:128)
at n.$digest (http://oditek.in/Gofasto/js/angularjs.js:130:206)
at n.$apply (http://oditek.in/Gofasto/js/angularjs.js:133:236)
at g (http://oditek.in/Gofasto/js/angularjs.js:87:376)
at K (http://oditek.in/Gofasto/js/angularjs.js:91:448)
at XMLHttpRequest.z.onload (http://oditek.in/Gofasto/js/angularjs.js:92:462)
我在下面解釋我的代碼。
<tbody id="detailsstockid">
<tr ng-repeat="ses in sectionData">
<td>{{$index+1}}</td>
<td>{{ses.colg_name}}</td>
<td>{{ses.session}}</td>
<td>
<!--<a ui-sref='dashboard.profile({p_i:profile.profile_id})'>
<input type='button' class='btn btn-xs btn-green' value='Edit' ng-click="reload();">
</a>-->
<a ui-sref='dashboard.res.session'>
<input type='button' class='btn btn-xs btn-green' value='Edit' ng-click="editSessionData(ses.session_id);">
</a>
</td>
<td>
<a ui-sref='dashboard.res.session'>
<input type='button' class='btn btn-xs btn-red' value='Remove' ng-click="deleteSessionData(ses.session_id);" >
</a>
</td>
</tr>
</tbody>
這是我的要求,當我提交表單時,數據將突然顯示在上面的列表中。請檢查下面的控制器部分。
var userdata={'colg_name':$scope.colg_name.value,'session':$scope.session};
$http({
method:'POST',
url:"php/resource/addSessionData.php",
data:userdata,
headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
}).then(function successCallback(response){
alert(response.data['msg']);
$scope.colg_name.value='';
$scope.session=null;
$scope.sectionData.unshift(response.data);
},function errorCallback(response) {
alert(response.data['msg']);
$state.go('dashboard.res.session',{}, { reload: true });
});
$http({
method:'GET',
url:"php/resource/readSessionData.php",
headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
}).then(function successCallback(response){
$scope.sessionData=response.data;
},function errorCallback(response) {
});
當用戶將數據插入后首次將數據插入數據庫時,應該在列表中顯示,但是在插入數據庫后,它會引發以下錯誤。
錯誤2:
TypeError: $scope.sectionData.unshift is not a function
at successCallback (resourceSessionController.js:48)
at angularjs.js:118
at n.$eval (angularjs.js:132)
at n.$digest (angularjs.js:129)
at n.$apply (angularjs.js:133)
at g (angularjs.js:87)
at K (angularjs.js:91)
at XMLHttpRequest.z.onload (angularjs.js:92)
請幫助我解決以上錯誤。
這是由數據sectionData
的重復值引起的。 您可以通過在ng-repeat
如下所示的軌道來解決此問題,如下所示,
<tr ng-repeat="ses in sectionData track by $index">
更新資料
if($scope.sectionData != null && $scope.sectionData.length > 0){
$scope.sectionData.unshift(response.data);
}
else{
$scope.sectionData = response.data;
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.