【问题标题】:Check Javascript nested obj value exists with unknown key检查Javascript嵌套obj值是否存在未知键
【发布时间】:2021-04-29 11:51:05
【问题描述】:

以下用于构建对象数组:

var users = {};

var user = {};
user[socket.id] = data.username;

if(users[data.roomname]){

   // Room already exists - check user already exists 

   // if data.username does not value exist is users then:

   users[data.roomname].push(user);
}
else{

   // New room

   users[data.roomname] = [user];
}

经过几次迭代,我们得到了这样的结果:

console.log ( 'Users: ', users );

users  { RoomABC:
   [ { YidwzgUHPHEGkQIPAAAD: 'Mr Chipps' },
     { 'JG-gtBMyPm0C1Hi1AAAF': 'Mr T' },
     { '2JFGMEdPbgjTgLGVAAAH': 'Mr Chipps' }, ] }

问题在于尝试确保每个用户名都是唯一的,因此如果该名称已存在,则不应再次添加 Mr Chipps

我见过的例子假设密钥是已知的。我尝试了很多方法,包括someindexOf,但我无法让一个简单的“UserX 是否已经存在”来工作。

以下是我尝试仅在 obj 数组中不存在时才添加用户的最新代码块。这行得通,但对我来说似乎很笨拙;嵌套循环以到达正确的级别以检查值并在找到匹配项时设置计数器,然后检查计数器以确定是否找到匹配项:

if(users[data.roomname]){

  // Room already exists - check user already exists 
                
  let found = 0;

  // Nested loop - seems a little clunky but it works

  Object.keys(users[data.roomname]).forEach(key => {

     Object.keys(users[data.roomname][key]).forEach(key2 => {

         if ( users[data.roomname][key][key2] === data.username ) {
            found++;
         }
     });
  });

  if ( found == 0 ) {
     users[data.roomname].push(user);
  }
}

我一直在想肯定有一个简洁的单线可以做这个检查是否存在,但我不能让任何工作。

【问题讨论】:

  • 如果一个用户是独一无二的,你不允许第二个同名用户,那么为什么不使用用户名作为键而不是套接字 ID?
  • 您可以使用 Set 并拥有各种内置方法
  • @mplungjan 我已经继承了这段代码,并且正在慢慢尝试解决一些错误。我认为关键是代码其他部分的重要价值。我只是想一次解决一个问题,第一个是重复用户问题。
  • @TenG ,而不是唯一键,使用它的值作为键,如User = { [data.username]: [socket.id] }

标签: javascript arrays javascript-objects key-value


【解决方案1】:

如果找到名称,您可以检查值而不是使用键并提前退出

if (users[data.roomname]) {
    if (!Object.values(users[data.roomname]).some(v => Object.values(v).some(n => n === data.username))) {
        users[data.roomname].push(user);
    }
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-02-05
    • 1970-01-01
    • 2021-09-05
    相关资源
    最近更新 更多