模态中的角度。无法弄清楚我的控制器出了什么问题

时间:2013-02-05 16:07:21

标签: javascript angularjs

我对角度很新,不能为我的生活弄清楚这段代码有什么问题。我很乐意根据需要提供更多代码。

问题是没有任何角度动作发生。该表未填充,并且没有按钮执行任何操作。 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/

1 个答案:

答案 0 :(得分:1)

以下是我注意到的问题:

  1. HTML中没有'ng-app'。
  2. locateNumbers函数有时返回null,但代码的其他部分期望locateNumber为数组。
  3. 我没有提供进一步的功能。您可以在此处找到更改的示例:http://plnkr.co/edit/A52VmYLznpNqMLq4XLK0?p=preview