如何嵌套if语句和&& (和)运算符在这个for循环中有区别吗?

时间:2017-07-21 19:55:30

标签: javascript arrays for-loop javascript-objects and-operator

这里有类似的问题,但我找不到与之相关的问题。这是我的问题:

这两个函数输出不同的结果。我的印象是&&运算符基本上与嵌套的if语句一样工作。我的结局显然存在一个误解/逻辑错误,即&& amp;操作员工作。我相信这与在循环中尝试同时读取条件或类似的东西有关,但如果有人能详细说明发生了什么,那将是值得赞赏的。和&&第二个函数中的运算符以及为什么输出未找到的属性?

var contacts = [
    {
        "firstName": "Harry",
        "lastName": "Potter",
        "number": "0994372684",
        "likes": ["Hogwarts", "Magic", "Hagrid"]
    },
    {
        "firstName": "Sherlock",
        "lastName": "Holmes",
        "number": "0487345643",
        "likes": ["Intriguing Cases", "Violin"]
    },
    {
        "firstName": "Kristian",
        "lastName": "Vos",
        "number": "unknown",
        "likes": ["Javascript", "Gaming", "Foxes"]
    },
    {
        "firstName": "Akira",
        "lastName": "Laine",
        "number": "0543236543",
        "likes": ["Pizza", "Coding", "Brownie Points"]
    }
];

function lookUp(arr, firstName, prop){
  for (var x = 0; x < contacts.length; x++){
    if (arr[x].firstName === firstName) 
      if (arr[x].hasOwnProperty(prop)) 
        return arr[x][prop];
      else 
        return "No such property";
  }
}

lookUp(contacts, "Kristian", "likes")
// ["Javascript", "Gaming", "Foxes"]

function lookUp(arr, firstName, prop){
  for (var x = 0; x < contacts.length; x++){
    if (arr[x].firstName === firstName && arr[x].hasOwnProperty(prop))  
      return arr[x][prop];
    else 
        return "No such property";
  }
}

lookUp(contacts, "Kristian", "likes")
// "No such property"

3 个答案:

答案 0 :(得分:3)

正确的功能如下所示:

function lookUp(arr, firstName, prop) {
    for (var x = 0; x < contacts.length; x++) {
        if (arr[x].firstName === firstName && arr[x].hasOwnProperty(prop)) 
            return arr[x][prop];
    }
    return "No such property";
}

说明

你的循环只有一次迭代,因为当第一个if为真时它将return arr[x][prop]或如果它为假,它将return "No such property"

return从函数中跳出总是,这就是循环停止的原因

而不是“正确”的解决方案将遍历所有数组元素,如果没有提供的名称,它将返回"No such property"

答案 1 :(得分:0)

第二个函数不等于第一个函数,因为内部if有else条件。

AND运算符只有在它变为真时才会执行后续条件。

例如:  如果条件是X == Y&amp;&amp; Y == Z然后Y == Z仅在X == Y

时执行

在第一种情况下为条件1添加一个,它看起来像:

 if Condition1 {

       if condition2

         console.log("1");

      else

            console.log("2");
    }
    else 

        console.log("3");

    Second Case

     If Condition1 && Condition2
       console.log("1");
     else
       console.log("2 and 3");  // all the case of 2 and 3 come here

答案 2 :(得分:0)

这是100%的工作

function lookUp(arr, firstName, prop){
    var lock;

    for(var i = 0; i < arr.length; i++)
    {
        if((arr[i].firstName == firstName) && (arr[i].hasOwnProperty(prop)))
        {
            lock = arr[i][prop];
            break;
        }else{
            lock = "No such property";
        }
    }
    return lock;
}