Angular отношения модели js
Я пробовал Angular JS в течение последних нескольких дней, и одна вещь, которую я не могу понять, - это как работать с отношениями между моделями.
В проекте, над которым я работаю, есть модель пользователей и модель учетных записей. Я установил в своей базе данных, что у каждой учетной записи есть поле с именем "ownBy", которое является ссылкой на внешний ключ для идентификатора пользователя, которому принадлежит эта учетная запись.
В Angular У меня есть следующая настройка в файле main.js
var myApp = angular.module('myApp', ['ngResource']);
var Users = myApp.factory('Users', function($resource) {
var User = $resource('http://api.mydomain.ca/users/:id',
{id:'@id'},
{});
return User;
});
var Accounts = myApp.factory('Accounts', function($resource) {
var Accounts = $resource('http://api.mydomain.ca/accounts/:id',
{id:'@id'},
{});
return Accounts;
});
function UsersCtrl($scope, Users) {
$scope.users = Users.query();
}
function AccountsCtrl($scope, Accounts) {
$scope.accounts = Accounts.query();
}
и следующий шаблон
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<title>Angular Test</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" href="/bootstrap/css/bootstrap.min.css?v=2.2.1">
</head>
<body>
<div ng-app="myApp">
<div ng-controller="UsersCtrl">
<table class="table table-striped">
<thead>
<tr>
<th>ID</th>
<th>First Name</th>
<th>Last Name</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="user in users">
<td>{{user.id}}</td>
<td>{{user.firstName}}</td>
<td>{{user.lastName}}</td>
</tr>
</tbody>
</table>
</div>
<div ng-controller="AccountsCtrl">
<table class="table table-striped">
<thead>
<tr>
<th>ID</th>
<th>Owned By</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="account in accounts">
<td>{{account.id}}</td>
<td>{{account.ownedBy}}</td>
</tr>
</tbody>
</table>
</div>
</div>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.0.4/angular.min.js"></script>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.0.4/angular-resource.min.js"></script>
<script src="/bootstrap/js/bootstrap.min.js?v=2.2.1"></script>
<script src="js/main.js"></script>
</body>
</html>
и это работает. Он извлекает ресурс JSON с моего сервера REST и отображает его в таблице. Какой следующий шаг я должен предпринять, чтобы закончить с одной таблицей, которая показывает пользователей и их номера счетов? (эквивалент базы данных JOIN?) Есть ли другой способ сделать это для отношений друг к другу? (то есть... учетная запись имеет много транзакций)
Спасибо за помощь:)
Ответы
Ответ 1
$resource
не имеет никакого отношения к отношениям, которые не обрабатываются сервером, но это довольно просто с $http
:
module.factory( 'UserService', function ( $http, $q ) {
return {
get: function getUser( id ) {
// We create our own promise to return
var deferred = $q.defer();
$http.get('/users/'+id).then( function ( user ) {
$http.get('/accounts/'+user.id).then( function ( acct ) {
// Add the account info however you want
user.account = acct;
// resolve the promise
deferred.resolve( user );
}, function getAcctError() { deferred.reject(); } );
}, function getUserError() { deferred.reject(); } );
return deferred.promise;
}
};
});
И затем в вашем контроллере вы можете просто использовать его, как и любое другое обещание:
UserService.get( $scope.userId ).then( function ( user ) {
$scope.user = user;
});
И он доступен для вашего шаблона!
<div>
User: "{{user.firstName}} {{user.lastName}}" with Acct ID "{{user.acct.id}}".
</div>
Ответ 2
Я использую js-data, если мне нужны отношения в пользовательском интерфейсе. Библиотека обрабатывает отношения и моделирование данных довольно элегантно в целом. Я нашел его проще в использовании, даже если вы просто ищете хороший интерфейс API. Я предпочитаю его ngResource.
В вашем случае у вас будет модель для пользователя и модели для учетной записи
src/app/data/account.model.coffee
angular.module 'app.data' #this can be your module name
.factory 'Account', (DS) ->
DS.defineResource
name: 'account'
endpoint: 'accounts'
relations:
belongsTo:
user:
localKey: 'userId'
localField: 'user'
src/app/data/user.model.coffee
angular.module 'app.data'
.factory 'User', (DS) ->
DS.defineResource
name: 'user'
endpoint: 'users'
relations:
belongsTo:
account: #make sure this matches the 'name' property of the other model
foreignKey: 'userId'
localField: 'account'