将数据从一个模块显示到另一个模块的问题

Issue to display data from a module into another

我是 MEAN.js 的初学者,在将一些数据从一个模块显示到另一个模块时遇到问题。

我已经成功创建了一个新的 CRUD 模块 "Jobs",其中包含我公司的职位列表。 我想将此列表中的作业关联到用户(这是示例代码中包含的另一个 crud 模块) 当我在管理面板上编辑用户时,我希望能够从列表中选择一个工作并将其设置为数据库中的用户。

这是我从现在开始的:

user.server.model.js

var UserSchema = new Schema({
  //username, firstname etc.
  job: {
    type: Schema.ObjectId,
    ref: 'job'
  }
});

job.server.model.js

var JobSchema = new Schema({
   name:{
      type: String
   }
});

我的html我尝试link他们两个:

编辑-user.client.view.html

//Set a job for a user
<select ng-options="job.name for job in vm.jobs"></select> // <--- this doesn't work

感谢您的帮助:)!

编辑: user.client.controller.js

angular.module('users.admin').controller('UserController', ['$scope', '$state', 'Authentication', 'userResolve',function ($scope, $state, Authentication, userResolve) {
$scope.authentication = Authentication;
$scope.user = userResolve; //...

job.client.controller.js

angular
    .module('jobs')
    .controller('JobsController', JobsController);

  JobsController.$inject = ['$scope', '$state', 'Authentication', 'jobResolve'];

  function RolesController ($scope, $state, Authentication, job) {
    var vm = this;

    vm.authentication = Authentication;
    vm.job = job; //...

列表-job.client.controller.js

angular
  .module('jobs')
  .controller('JobsListController', JobsListController);
JobsListController.$inject = ['JobsService'];
function JobsListController(JobsService) {
  var vm = this;
  vm.roles = JobsService.query();
}

已解决,将我的工作服务注入我的用户控制器就成功了:

angular.module('users.admin').controller('UserController', ['$scope', '$state', 'Authentication', 'JobsService', 'userResolve',
  function ($scope, $state, Authentication, JobsService, userResolve) {
    $scope.authentication = Authentication;
    $scope.user = userResolve;
    $scope.jobs = JobsService.query();

这必须在您的服务器端端点中完成。 假设你有这样一条路线:

router.post('/users/', function(req, res, next) {
    var user = new User(req.body);
    user.job = req.job;

    user.save(function(err, user) {
         if(err) { return next(err); }        
         res.json(user);
    });
});