首页 > 解决方案 > Loopback:如何在 afterRemote 中访问关系

问题描述

我为仓库模型设置了以下 afterRemote 方法:

  Depot.afterRemote('find', function(context, depots, next) {

        context.result.forEach(depot => {
          console.log(depot.drivers);
          depot.address = depot.street_name + ' ' + depot.door_number;
          depot.driver_count = depot.drivers.length;
        });

        next()
      })

在 json 响应中 depot.drivers 包含正确的数据。

但是,当我尝试在上述方法中访问 depot.drivers 时,会得到一些奇怪的输出:

{ [Function: f]
  _receiver: { postal_code: '1216BS',
     door_number: '3',
     street_name: 'Straat naam',
     city: 'Hilversum',
     lat: null,
     lng: null,
     created: 2018-04-03T01:49:12.000Z,
     id: 23,
     distributor_id: 2,
     distributor: { sys_id: 1,
        name: 'distributeur naam',
        contact_person: 'Persoon B',
        phone: '000-000000',
        email: 'info@d.nl',
        created: 2018-03-06T00:22:33.000Z,
        id: 2 },
     drivers: List [] },
  _scope: { where: { hub_id: 23 } },
  _targetClass: 'driver',
  find: [Function],
  getAsync: [Function],
  build: [Function: bound method],
  create: [Function: bound method],
  updateAll: [Function: updateAll],
  destroyAll: [Function: destroyAll],
  findById: [Function: bound method],
  findOne: [Function: findOne],
  count: [Function: count],
  destroy: [Function: bound method],
  updateById: [Function: bound method],
  exists: [Function: bound method] }

我最终想添加一个 depot.drivers_count 属性,这样我就可以在前端表中显示连接到特定仓库的驱动程序数量。

任何人都知道如何做到这一点?

标签: loopbackjs

解决方案


看起来数据没有转换为 JSON。

我会试试这个:

context.result.forEach(depot => {
      depot = depot.toJSON();
      console.log(depot.drivers);
      depot.address = depot.street_name + ' ' + depot.door_number;
      depot.driver_count = depot.drivers.length;
 });

推荐阅读