在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問答/HTML5  HTML/ js判斷數(shù)組是否包含某個(gè)元素,自己寫了個(gè)函數(shù),不知哪出了問題?

js判斷數(shù)組是否包含某個(gè)元素,自己寫了個(gè)函數(shù),不知哪出了問題?

var arr = [
    {
        id:1,
        name:"mincoo"
    },
    {
        id:2,
        name:"tomorrow"
    }
];
//參數(shù):(要檢測(cè)的數(shù)組,要檢測(cè)的字段,要檢測(cè)哪個(gè)key)
function isContainKey(arr,value,keyName){
    for(var i=0;i<arr.length;i++){
        if(arr[i].keyName == value){
            return false; //發(fā)現(xiàn)含有此元素
        }
        else{
            return true; //沒有找到
        }
        console.log(arr[i].keyName); 
    }
}
isContainKey(arr,"tomorrow","name");

我想要的效果:
如果檢測(cè)到這個(gè)數(shù)組包含此元素,返回true,否則返回false。
但是我這里寫的白屏了,是什么原因呢?

回答
編輯回答
墻頭草

兩個(gè)問題:

  1. keyName應(yīng)當(dāng)寫在防括號(hào)內(nèi),你寫在.后面,程序把他當(dāng)做了下標(biāo);
  2. 只有在檢測(cè)到這個(gè)元素時(shí),才在for循環(huán)內(nèi)執(zhí)行return,另一個(gè)return應(yīng)當(dāng)在for循環(huán)的外面,你的程序是只能檢測(cè)第1個(gè)元素是否匹配,然后返回true和false;

還有,你這里既然是檢測(cè)數(shù)組里的某項(xiàng)是否包含這個(gè)數(shù)組,如果檢測(cè)到的話,應(yīng)該返回true呀,可是你為什么想要返回false呢?

var arr = [
    {
        id:1,
        name:"mincoo"
    },
    {
        id:2,
        name:"tomorrow"
    }
];
//參數(shù):(要檢測(cè)的數(shù)組,要檢測(cè)的字段,要檢測(cè)哪個(gè)key)
function isContainKey(arr,value,keyName){
    for(var i=0;i<arr.length;i++){
        if(arr[i][keyName] == value){
            return true; //發(fā)現(xiàn)含有此元素
        }
    }
    return false;
}
console.log( isContainKey(arr,"tomorrow","name") );
2018年1月24日 07:10
編輯回答
不將就

你寫這個(gè)只循環(huán)了一次

function isContainKey (arr, key, value) {
  return arr.some(v => {
    return v[key] === value
  })
}
2017年7月21日 16:34
編輯回答
茍活

你在for循環(huán)中寫了兩個(gè)return語句,當(dāng)?shù)谝淮窝h(huán)進(jìn)入的時(shí)候,不管對(duì)象中是否存在你所需要判斷的key值,你都跳會(huì)出這個(gè)循環(huán),并且不再執(zhí)行后續(xù)操作,你將一個(gè)return移到for循環(huán)外就可以了。當(dāng)然你最好是key值存在的時(shí)候返回true,因?yàn)槟愕姆椒?code>isContainKey,還有一點(diǎn),對(duì)于這種函數(shù)方法你寫幾個(gè)console.log打印下就可以測(cè)試出來的,所以你最好自己多測(cè)試一下

function isContainKey(arr,value,keyName){
    for(var i=0;i<arr.length;i++){
      console.log(arr[i])
        if(arr[i].keyName == value){
            return true; //發(fā)現(xiàn)含有此元素
        }
    }
    return false
}
2017年12月12日 16:50
編輯回答
笑浮塵

你這是找數(shù)組第一個(gè)的對(duì)象的叫keyName屬性等不等于value

function isContainKey(arr,value,keyName){
    for(var i=0;i<arr.length;i++){
        if(arr[i][keyName] == value){
            return true; //發(fā)現(xiàn)含有此元素
        }
    }
    return false;
}

其次為何要寫著方法,不本來就有么。

arr.some(({ name }) => name === 'tomorrow' )
2018年8月13日 16:45
編輯回答
葬憶

四處問題:

function isContainKey(arr,value,keyName){
    for(var i=0;i<arr.length;i++){
        // 這里應(yīng)該是 arr[i][keyName],你的寫法會(huì)去找元素的 'keyName' 屬性
        if(arr[i].keyName == value){
            return false; //發(fā)現(xiàn)含有此元素 // 按照你的題意,這里應(yīng)該返回 true 的。
        }
        else{
            return true; //沒有找到 // 按照你的題意,這里應(yīng)該返回 false 的。
        }
        // 你讓兩個(gè)分支都包含 return 了,這意味著這個(gè)循環(huán)最多只能循環(huán)一次
        console.log(arr[i].keyName); 
    }
}

應(yīng)該改為:

function isContainKey(arr,value,keyName){
    for(var i=0;i<arr.length;i++){
        if(arr[i][keyName] === value){
            console.log(arr[i].keyName); 
            return true; //發(fā)現(xiàn)含有此元素
        }
    }
    return false;
}
2017年4月27日 16:29
編輯回答
萌二代

樓上已經(jīng)說明了原因所在。
這就像 官兵抓逃犯,假設(shè)逃犯藏在某個(gè)居民家中。官兵敲了一家居民甲的門,問逃犯在你家嗎。如果恰好在呢,那么抓捕成功,如果不在呢,就要接著去敲下一家乙的門,對(duì)不對(duì)。你這里寫了一個(gè)return,直接宣告抓捕失敗,打道回府了。

2017年8月8日 02:40