Угловой UI-выбрать выбранное значение по умолчанию

Я использую ui-select в Angular, чтобы иметь поле выбора на моей странице. Я могу искать, печатая, и когда я выбираю значение, будет отображаться имя [Это нормально], а ng-модель имеет выбранные значения id[что также правильно]

Сейчас я пытаюсь загрузить вид уже сохраненной записи. Я хочу, чтобы выбранный ящик был предварительно заполнен.

Но это не так!

Это мой HTML

<ui-select ng-model="vm.product.category">
    <ui-select-match placeholder="Type to search">{{ (vm.categories | filter : { id : vm.product.category } : true)[0].name }}</ui-select-match>
    <ui-select-choices repeat="category.id as category in (vm.categories | filter: {name: $select.search})">
        <span ng-bind-html="category.name | highlight: $select.search"></span>
    </ui-select-choices>
</ui-select>

Вот мой контроллер,

app.controller('productDetailsController', [
    '$scope', 'Product',
    function ($scope, Product) {
        var vm = this;
        vm.product = {};
        vm.categories = [{name: "General", id: "1"}, {name: "Product", id: "2"}]

        Product.get({id: id}).$promise.then(function (data) {
            vm.product = data.data;
        }, function (error) {
            alert(error);
        });
    }
]);

Когда я загружаю запись из базы данных, моя модель () имеет идентификатор. но я хочу, чтобы имя отображалось пользователю.

Как я могу это сделать? Что я здесь не так делаю?

Заранее спасибо!

1 ответ

var app = angular.module('app', ['ui.select']);
app.service('myservice', ['$timeout', '$q',
  function($timeout, $q) {
    this.getData = function() {
      var defer = $q.defer();
      //Here, $timeout corresponds to $http
      $timeout(function() {
        defer.resolve({
          'data': {
            product_name: "Galaxy S3",
            product_description: "Galaxy S3 desc",
            category: 1,
            is_active: true
          }
        });
      }, 1000);
      return defer.promise;
    }
  }
]);
app.controller('productDetailsController', ['$scope', 'myservice',
  function($scope, myservice) {
    var vm = this;
    vm.product = {};
    vm.categories = [{
      name: "General",
      id: "1"
    }, {
      name: "Product",
      id: "2"
    }];

    myservice.getData().then(function(data) {
      vm.product = data.data;
    });

  }
]);
<link href="http://netdna.bootstrapcdn.com/bootstrap/3.1.1/css/bootstrap.css" rel="stylesheet" />
<link href="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-select/0.11.2/select.css" rel="stylesheet" />
<script src="http://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.15/angular.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-select/0.11.2/select.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.15/angular-sanitize.js"></script>

<div ng-app="app" ng-controller="productDetailsController as vm">
  <ui-select ng-model="vm.product.category">
    <ui-select-match placeholder="Type to search">{{$select.selected.name}}</ui-select-match>
    <ui-select-choices repeat="category.id as category in vm.categories | filter: {name: $select.search}">
      <div ng-bind="category.name | highlight: $select.search"></div>
    </ui-select-choices>
  </ui-select>
</div>

Другие вопросы по тегам