angularjs xeditable - ng-options

时间:2016-11-28 12:34:39

标签: angularjs x-editable

我从选定的经销商处获取ID时遇到问题。这是我的选择经销商的HTML代码

<span editable-select="currentKlupa.distributor" e-form="tableform" e-ng-options="user as user for user in getAllUserFromRolesPushano">{{::currentKlupa.distributor.username}}
                            </span>

我还有另一个选择框,所有工作都正确,但这不是,因为我需要从这个选择中获取id。

这是控制器

$scope.getUserFromRoles = function (rolaProslijedena) {
        $scope.getAllUserFromRolesPushano = [];
        $scope.getAllUserFromRoles = dohvacanjeUseraPoRolama.get({rola: rolaProslijedena});
        $scope.getAllUserFromRoles.$promise.then(function (data) {
            angular.forEach(data.users, function (key, value){
                $scope.getAllUserFromRolesPushano.push(key.username);
            });

        });
    };

我需要从这个选定的经销商处获取id,如何为此设置ng-options?日Thnx

1 个答案:

答案 0 :(得分:2)

如果没有更多信息,我会举例说明一些技巧(我还没有找到更好的解决方案):

我有一个显示由艺术家完成。

$scope.shows = {artist_id : 4};

艺术家名单

$scope.artists = [{id : 1, name : 'artist1'},{id : 2, name : 'artist2'},...];

我的HTML将是:

<span editable-select="shows.artist_id" e-name="name" e-form="rowform"  e-ng-options="g._id as g.name for g in artists">
    {{DisplayName(shows)}}
</span>

技巧是使用DisplayName。

$scope.DisplayName= function(item) {
  var selected = $scope.artists.filter(function( obj ) {return (obj._id == item.artist_id)})[0]
  return selected.name;
};

这真的不是最好的解决方案,但是有效。