1

给定如下的数组和数据结构,我想从表字段tags中删除与removeVals匹配的任何值。我找到了更改的解决方案,并尝试使用deleteAt,但得到了indexOf is not a function错误。

var removeTags = ["val1", "val3"];

{
  name: "test1",
  tags: ["val1", "val2", "val3", "val4", "val5"]
}

所以我应该留下:

{
  name: "test1",
  tags: ["val2", "val4", "val5"]
}

到目前为止我的代码:

var removeTags = ["val1", "val2"]
r.db('test').table('data').get('test1').update(function(row) {
  return row('tags').indexesOf(function(rl) {
    return r.expr(removeTags).contains(rl)
  })(0).do(function(idx) {
    return {
      roles: row('tags').deleteAt(idx)
    }
  })
});

这是我用作参考的问题/答案。任何帮助将不胜感激,非常感谢!

4

1 回答 1

7

没关系,我找到了答案,而且比我想象的要容易得多,我把事情复杂化了!

var removeTags = ['val1', 'val2'];
r.db('test').table('data').get('test1')
  .update({tags: r.row('tags').difference(removeTags)});

无论如何,希望这对其他人有帮助

于 2016-09-16T09:49:42.400 回答