[英]Reset the changed values doesn't work in other Ctrl (AngularJS)
我對我的問題有點困惑。 實際上,我有2個正在使用服務的視圖和ctrl。 “第一視圖”包含一個列表列表,其中包含將從WebAPI加載的項目。 該服務向服務器發出請求並按訂單提供。 另外,我正在使用另一項服務在另一項Ctrl中轉移所選項目行。 這是代碼:
視圖1:
//view1.html
<table class="table table-bordered table-hover">
<thead>
<tr>
<th>Firstname</th>
<th>Lastname</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="item in namelist" ng-click="open(this.item)">
<td>{{ item.fname }}</td>
<td>{{ item.lname }}</td>
</tr>
</tbody>
</table>
Ctrl1:
//FirstCtrl
$scope.namelist = reqService.names.query();
$scope.open = function (item) {
$scope.selectedItem = item;
modalService.openDialog($scope.namelist, $scope.selectedItem);
}
HTTP服務:
//Service for HTTP Requests
testApp.factory('reqService', ['$resource', 'baseUrl', function ($resource, baseUrl) {
return {
names: $resource(baseUrl + '/api/name/:Id', {
Id: '@Id'
}, {
'update': {
method: 'PUT'
}
})
}
}]);
模態對話框服務:
//Modal dialog service
testApp.factory('modalService', ['$modal', function ($modal) {
return {
openDialog: function (namelist, selectedItem) {
return $modal.open({
templateUrl: 'views/view2.html',
controller: 'SecondCtrl',
resolve: {
namedList: function () {
return namelist;
},
selected: function () {
return selectedItem;
}
}
});
}
}
}]);
Ctrl2:
testApp.controller('SecondCtrl', ['$scope', '$modalInstance', 'namedList', 'selected', 'reqService', '$http'..., function (...){
/*copy of the original items*/
$scope.copyItem = angular.copy(selected);
$scope.cancel = function () {
$scope.selected = angular.copy($scope.copyItem);
$modalInstance.dismiss('cancel');
}
$scope.reset = function () {
$scope.selected = angular.copy($scope.copyItem);
selected = angular.copy($scope.copyItem); //doesn't work
}
}
我的問題是如何重置表列表? 當我單擊resetBtn時,它僅重置我的模式窗口中的表單,但更改仍保留在表列表中? 我無法重置解析變量“已選擇”。
可以根據情況通過。
閱讀本文JavaScript是引用傳遞還是值傳遞語言? 。
如果嘗試通過傳遞重置值的函數來查看其工作原理,將很有趣。
Ctrl1:
$scope.open = function (item) {
$scope.selectedItem = item;
modalService.openDialog($scope.namelist, function(e){
if (e === undefined) {
return $scope.selectedItem;
} else {
$scope.selectedItem = e;
}
});
}
Ctrl2開始:
testApp.controller('SecondCtrl', ['$scope', '$modalInstance', 'namedList', 'selected', 'reqService', '$http'..., function (...){
/*copy of the original items*/
$scope.copyItem = angular.copy(selected());
$scope.cancel = function () {
$scope.selected = angular.copy($scope.copyItem);
$modalInstance.dismiss('cancel');
}
$scope.reset = function () {
$scope.selected = angular.copy($scope.copyItem);
selected(angular.copy($scope.copyItem));
}
}
好的,我知道它很臟,但這只是為了檢驗假設。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.