我对角度很新,不能为我的生活弄清楚这段代码有什么问题。我很乐意根据需要提供更多代码。
问题是没有任何角度动作发生。该表未填充,并且没有按钮执行任何操作。 http get永远不会进入我的服务器。所以,我想知道是否有人不介意快速看一下,如果我犯了一个愚蠢的错误就让我知道。
这是我的角度代码:
function locateController($scope, $http) {
$scope.init = function () {
$http.get('@(Url.Action<WorkorderController>(c => c.GetLocateNumbers(Model.Id)))').success(function (data) {
$scope.model = data;
$scope.locateNumber = $scope.locateNumbers();
$("#loading").css('display', 'none');
$("#ctrl").css('visibility', 'visible');
$scope.master = angular.copy($scope.model);
});
};
$scope.init();
$scope.reset = function () {
if (confirm('Are you sure you want to discard all your changes?')) {
$scope.model = angular.copy($scope.master);
$(".selected").removeClass("selected");
$scope.locateNumber = $scope.locateNumbers();
};
};
$scope.removeLocate = function (remove) {
if (confirm('Are you sure you want to remove this location number?')) {
var oldLines = $scope.locateNumber;
$scope.labor = [];
angular.forEach(oldLines, function (line) {
if (line != remove) $scope.locateNumber.push(line);
});
}
};
$scope.locateNumbers = function () {
if (!$scope.model) {
return null;
}
var lines = [];
angular.forEach($scope.model, function (item) {
if (item.IsActive) {
lines.push(item);
}
});
return lines;
};
$scope.addLocateLine = function () {
$scope.locateNumber.push({
locationNum: ''
});
};
$scope.dirty = function () {
if ($scope.model === undefined) {
return false;
}
var isDirty = !angular.equals($scope.locateNumber, $scope.master.locateNumbers);
if (isDirty) {
$scope.notice = null;
}
return isDirty;
};
$scope.save = function () {
$scope.model.Size = $scope.locateNumber.length;
$scope.model.locateNumbers = $scope.locateNumber;
$http({
method: 'post',
url: '@(Url.Action<WorkorderController>(c => c.AssignLocate(Model.Id,null)))',
headers: {
"Content-Type": 'application/json',
Accepts: 'application/json'
},
data: { wo: $scope.model }
}).success(function (data, status, headers, config) {
$scope.init();
}).error(function (data, status, headers, config) {
alert('An error has occurred. Please try again later or contact an administrator');
});
};
};
这是HTML:
<div class="modal hide" id="assignLocate" data-ng-controller="locateController">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal">×</button>
<h3 class="addRow">Locate Number <button type="button" class="btn btn-warning btn-mini" data-ng-click="addLocateLine()">Add</button></h3>
</div>
<div>
<div class="span3 offset1">
<table cellpadding="0" cellspacing="25" border="0" class="table" id="locateNumbers">
<thead>
<tr>
<th>Locate Number</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="num in locateNumber">
<td>
<ng-form name="LocateNum">
<input type="text" ng-model="num.LocateNum" class="span2" required name="Input"/>
<span class="alert-error" ng-show="LocatenNum.Input.$error.required"><strong>*Required</strong></span>
</ng-form>
</td>
<td>
<button class="btn btn-mini btn-danger" ng-click="removeLocate(line)">Remove</button>
</td>
</tr>
</tbody>
</table>
<br /><br />
<div>
<div class="span3" style="padding-bottom:25px; margin-left: 0px">
<button type="button" class="btn btn-inverse" ng-click="reset()" ng-disabled="!dirty()">Reset</button>
<button type="button" class="btn btn-primary pull-right" ng-disabled="form.$invalid" ng-click="save()" ng-disabled="!dirty()">Save</button>
</div>
</div>
</div>
</div>
</div>
这是一个小提琴: http://jsfiddle.net/exmMY/
答案 0 :(得分:1)
以下是我注意到的问题:
locateNumbers
函数有时返回null
,但代码的其他部分期望locateNumber
为数组。我没有提供进一步的功能。您可以在此处找到更改的示例:http://plnkr.co/edit/A52VmYLznpNqMLq4XLK0?p=preview