方法:1、利用for語句遍歷數組,將數組元素和指定值進行比較,相等則存在;2、使用indexOf方法,如果元素存在于數組中則返回下標值,不存在則返回“-1”;3、利用inArray()方法,如果元素存在則返回下標值,不存在則返回“-1”。
創新互聯長期為近千家客戶提供的網站建設服務,團隊從業經驗10年,關注不同地域、不同群體,并針對不同對象提供差異化的產品和服務;打造開放共贏平臺,與合作伙伴共同營造健康的互聯網生態環境。為田陽企業提供專業的成都做網站、網站建設,田陽網站改版等技術服務。擁有十年豐富建站經驗和眾多成功案例,為您定制開發。
本教程操作環境:windows7系統、javascript1.8.5&&jquery1.10.2版、Dell G3電腦。
js中存在一個數組,如何判斷一個元素是否存在于這個數組中呢,首先是通過循環的辦法判斷,代碼如下:
var arr = ['a','s','d','f'];console.info(isInArray(arr,'a'));//循環的方式/** * 使用循環的方式判斷一個元素是否存在于一個數組中 * @param {Object} arr 數組 * @param {Object} value 元素值 */function isInArray(arr,value){ for(var i = 0; i < arr.length; i++){ if(value === arr[i]){ return true; } } return false;}這種方式是比較通用的一種方式,但是需要自己寫函數,下面看一下第二種方式:
var arr = ['a','s','d','f'];console.info(arr.indexOf('a'));//在IE某些版本中不支持,可以自行擴展這種方式是直接使用數組的indexOf方法來判斷,如果元素存在于數組中,那么返回元素在數組中的下標值,如果不存在,那么返回-1,注意indexOf是區分大小寫的,字母O必需大寫,不然是會報錯的,另外,該方法在某些版本的IE中是不起作用的,因此在使用之前需要做一下判斷,修改后的代碼如下所示:
/** * 使用indexOf判斷元素是否存在于數組中 * @param {Object} arr 數組 * @param {Object} value 元素值 */function isInArray3(arr,value){ if(arr.indexOf&&typeof(arr.indexOf)=='function'){ var index = arr.indexOf(value); if(index >= 0){ return true; } } return false;}第三種方式,就是使用jquery的inArray方法,該方法返回元素在數組中的下標,如果不存在與數組中,那么返回-1,代碼如下所示:
/** * 使用jquery的inArray方法判斷元素是否存在于數組中 * @param {Object} arr 數組 * @param {Object} value 元素值 */function isInArray2(arr,value){ var index = $.inArray(value,arr); if(index >= 0){ return true; } return false;}這種方式可以用來刪除一個數組中的未知下標值的元素,代碼如下所示:
var arr = ['a','s','d','f'];console.info("刪除元素之前的數組:"+arr);arr.splice($.inArray('a',arr),1);console.info("刪除元素之后的數組:"+arr);執行結果是:
[Web瀏覽器] "刪除元素之前的數組:a,s,d,f" /test/index.html (12)[Web瀏覽器] "刪除元素之后的數組:s,d,f" /test/index.html (14)【相關推薦:javascript學習教程】
                本文標題:javascript怎么判斷值是否在數組中
                
                文章網址:http://www.yijiale78.com/article40/cghceo.html
            
成都網站建設公司_創新互聯,為您提供小程序開發、網站營銷、移動網站建設、商城網站、品牌網站設計、網頁設計公司
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯
