javascript - AngularJS ngtable 无法正确显示数据

标签 javascript html angularjs ngtable

我有一个 ngTable,其中加载了对 webapi 的“Get”调用所产生的数据。然后我重新加载表格,但数据没有显示。

这是 *.js 文件

rdapp.controller('scoringTableCtrl', ['$location', '$scope', '$http', 'ngTableParams', '$filter',
function($location, $scope, $http, ngTableParams, $filter) {
    $scope.teamList = [];
    $http({
        method: 'GET',
        url: 'http://localhost:34592/api/scoringTable',
        headers: {
            'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
        }
    }).then(function(success) {
        $scope.teamList = success.data;
        addFieldsForSorting();
        $scope.dataTable.reload();
    }, function(error) {
        console.log(error);
    });
    $scope.resolveHTML = function(position) {
        if (position == 1 || position == 2 || position == 3) return 'champions';
        if (position == 4) return 'champions-prev';
        if (position == 5 || position == 6) return 'europa-league';
        if (position == 18 || position == 19 || position == 20) return 'decline';
        return '';
    }

    function addFieldsForSorting() {
        // Add named properties for every stat value in recipients array, used for sorting the grid.
        // Take value from vitalStats array, use alertIds to match between alpha keys and numeric keys.
        $scope.teamList.forEach(function(team) {
            for (var property in team) {
                if (!team.hasOwnProperty(property)) {
                    continue;
                }
                if (property == 'name') {
                    continue;
                }
                if (property == 'position') {
                    continue;
                }
                var prop = 'sort_' + property;
                team[prop] = -(team[property]);
            }
            team['sort_name'] = team.name;
            team['sort_position'] = team.position;
        });
    }
    $scope.dataTable = new ngTableParams({
        page: 1, // show first page
        count: 20, // count per page
        sorting: {
            sort_position: 'asc' // initial sorting
        }
    }, {
        counts: [],
        total: $scope.teamList.length, // length of data
        getData: function($defer, params) {
            // use build-in angular filter
            var requestData = $scope.teamList;
            var orderedData = params.sorting() ? $filter('orderBy')(requestData, params.orderBy()) : requestData;
            params.total(orderedData.length); // set total for recalc pagination
            $defer.resolve(orderedData.slice((params.page() - 1) * params.count(), params.page() * params.count()));
        }
    });
}
 ]);

这是我的 html:

<div class="position-view" style="position:relative; top:100px;">
<table ng-table="dataTable" class="table table-bordered table-border-important" ng-class="rec_spinner">
    <tbody class="text-center">{{$data.length}}
        <tr ng-repeat="team in $data">
            <td class="{{resolveHTML(team.position)}}" data-title="''" sortable="'sort_position'">
                {{team.position}}
            </td>
            <td data-title="'Clasificación'" sortable="'sort_name'">
                {{team.name}}
            </td>

            <!--Total Stats-->
            <td data-title="'PJ'" sortable="'sort_pj'">
                {{team.pj}}
            </td>
            <td data-title="'PG'" sortable="'sort_pg'" >
                {{team.pg}}
            </td>
            <td data-title="'PE'" sortable="'sort_pe'" >
                {{team.pe}}
            </td>
            <td data-title="'PP'" sortable="'sort_pp'" >
                {{team.pp}}
            </td>
            <td data-title="'GF'" sortable="'sort_gf'">
                {{team.gf}}
            </td>
            <td data-title="'GC'" sortable="'sort_gc'">
                {{team.gc}}
            </td>
            <td data-title="'PT'" sortable="'sort_pt'">
                {{team.pt}}
            </td>


        </tr>
    </tbody>
</table>

$data 没有任何数据,但如果我尝试 {{dataTable}} 我已正确加载所有数据。有人能帮我解决这个问题吗?也许有一些明显的我遗漏的东西,但关键是该表无论如何都创建了行和列的数量,但却是空的,这很奇怪。

最佳答案

经过长时间的搜索,我发现问题很简单,是关于驼峰命名法的。问题是当您从 Web api 发送信息时,如果您没有为参数设置自定义表示法,则它们将以大写的第一个字母发送。 因此,我们在这里有两个选择,建立自定义符号或仅在 HTML 中使用大写的第一个字母。我希望这对将来的人有所帮助!

关于javascript - AngularJS ngtable 无法正确显示数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46031030/

相关文章:

angularjs - 为什么 AngularJS 指令(属性等)在 WebStorm 8 中显示为 "invalid"?

javascript - 如何在现有的 django 网站上开始使用 React

html - 在两行之间制作小标题

javascript - 尽管隐含了未知数,但序数刻度没有正确着色?

javascript - 谷歌地图缩放功能不起作用

javascript - 用于光滑 slider 的自定义上一个和下一个按钮

html - 存在警报时的条件间隔

css - 动画,AngularJS : Animation speed in pixels per second?

javascript - 仅对背景位置 X 轴进行动画处理

javascript - 在 TypeScript 中获取 jQuery 插件到 "see"jQuery