4

我使用 lodashfind从数组中查询对象,然后设置该对象的属性,但是当我在设置此属性后打印出数组时,它没有改变。

对于在 JavaScript 中使用 lodash 处理对象方面更有经验的人的一些评论,我将不胜感激。也可以随意评论我提出问题的方式或编辑内容以使其更容易通过搜索引擎被其他人搜索。

隔离代码:

console.log('socket.io', token);
console.log(realtime);
let session = yield _.find(realtime, function(data) {
    return data.token === token;
});
console.log('session object to be set');
console.log(session);
if (!session.socket) {
    console.log('setting session for '+session.token+' socket '+socket.id);
    session.socket = socket.id;
    console.log('local reference after set');
    console.log(session);
    console.log('realtime after set');
    console.log(realtime);
}

结果,这是来自的输出console.log

socket.io 268fc477-d4ee-4ed4-88cd-648539397df2
[ { token: '268fc477-d4ee-4ed4-88cd-648539397df2' } ]
session object to be set
{ token: '268fc477-d4ee-4ed4-88cd-648539397df2' }
setting session for 268fc477-d4ee-4ed4-88cd-648539397df2 socket /#iEqqcIsBbATDs1a-AAAB
local reference after set
{ token: '268fc477-d4ee-4ed4-88cd-648539397df2',
socket: '/#iEqqcIsBbATDs1a-AAAB' }
realtime after set
[ { token: '268fc477-d4ee-4ed4-88cd-648539397df2' } ]

预期的结果,看最后的打印,我想在对象起源的数据结构中修改这个对象:

socket.io 268fc477-d4ee-4ed4-88cd-648539397df2
[ { token: '268fc477-d4ee-4ed4-88cd-648539397df2' } ]
session object to be set
{ token: '268fc477-d4ee-4ed4-88cd-648539397df2' }
setting session for 268fc477-d4ee-4ed4-88cd-648539397df2 socket /#iEqqcIsBbATDs1a-AAAB
local reference after set
{ token: '268fc477-d4ee-4ed4-88cd-648539397df2',
socket: '/#iEqqcIsBbATDs1a-AAAB' }
realtime after set
[ {
token: '268fc477-d4ee-4ed4-88cd-648539397df2',
socket: '/#iEqqcIsBbATDs1a-AAAB'
} ]

公共要点,也可以在这里发表评论。我希望这个问题对其他人也有用。

编辑 Lodash引用Returns the matched element, else undefined.我不确定这是否意味着它返回克隆对象或对查询对象的引用。

4

1 回答 1

3

发生的事情是您产生的值是一个对象,根据co文档,它将对象中的每个值视为要解决的承诺,并将返回一个具有相同键和值的(新)对象作为已解决的承诺。

在您的情况下,由于属性(例如token)的值不是承诺,因此值按原样传递,因此返回的对象看起来像您产生的对象,但实际上它是一个新对象,而不是内部对象realtime. co创建这个新对象的代码在这里

if (isObject(obj)) return objectToPromise.call(this, obj);

为了防止这种情况发生,你需要做

let session = yield Promise.resolve(_.find(realtime, data => data.token === token));

如果你产生了一个单一的标量值,co就会抱怨这不是一个可产生的。但是,由于您产生了一个对象值,co因此将其解释为可产生的对象类型。这引发了一个问题——你为什么一开始就试图产生一个不可屈服的东西?

最后一点:

Lodash 参考说返回匹配的元素,否则未定义。我不确定这是否意味着它返回克隆对象或对查询对象的引用。

当然,_.find返回找到的元素本身,而不是它的克隆。

于 2016-03-19T06:57:50.380 回答