js數(shù)組對(duì)象的includes方法使用
js數(shù)組對(duì)象的includes方法
判斷數(shù)組中是否有某個(gè)元素, 有就返回true, 沒有就返回false
let arr= [10,20,30,40]; console.log(arr.includes(10));//true console.log(arr.includes(100));//false
只能判斷簡單類型的數(shù)據(jù),對(duì)于復(fù)雜類型的數(shù)據(jù),比如對(duì)象類型的數(shù)組,二維數(shù)組,這些是無法判斷的
includes與indexOf的區(qū)別
includes()返回的是布爾值,能直接判斷數(shù)組中存不存在這個(gè)值,而indexOf()返回的是索引
假如你只想知道某個(gè)值是否在數(shù)組中而并不關(guān)心它的索引位置,建議使用includes()。
如果你想獲取一個(gè)值在數(shù)組中的位置,那么你只能使用indexOf方法
關(guān)于數(shù)組API includes的注意事項(xiàng)
includes 可以用來判斷 數(shù)組里面是否包含哪個(gè)值,(或者字符串里面是否包含某個(gè)字符串);
但是注意
對(duì)于數(shù)組里面包含的是對(duì)象(類似以下這種格式的),includes 是不能判斷的,加入你用它來進(jìn)行判斷 那么它每次都只會(huì)返回給你一個(gè) false;
按我個(gè)人理解
includes 判斷的是完全相等(也就是 === )然而由于 對(duì)象 是一個(gè)復(fù)雜數(shù)據(jù)類型
所以每一個(gè)對(duì)象都不可能完全相等的(對(duì)象與對(duì)象之間頂多也就是 ==)
所以這個(gè)時(shí)候使用 incluedes 它每次據(jù)只會(huì)給你返回 false
[ { time: 12345, page: 2 }, { time: 12345, page: 2 } ]
當(dāng)然:
如果你想要使用判斷像上面數(shù)組是否包含某個(gè)對(duì)象(或者對(duì)象里面某個(gè)value值)
你完全可以使用 findIndex 或者 find 等API
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于ligerui子頁面關(guān)閉后,父頁面刷新,重新加載的方法
今天小編就為大家分享一篇關(guān)于ligerui子頁面關(guān)閉后,父頁面刷新,重新加載的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-09-09Three.js+React使二維圖片呈現(xiàn)3D效果
這篇文章主要為大家介紹了如何利用Three.js+React技術(shù)棧,將二維漫畫圖片轉(zhuǎn)化為三維視覺效果。文中的實(shí)現(xiàn)方法講解詳細(xì),需要的可以參考一下2022-02-02js 動(dòng)態(tài)為textbox添加下拉框數(shù)據(jù)源的方法
這篇文章主要介紹了js 動(dòng)態(tài)為textbox添加下拉框數(shù)據(jù)源的方法,需要的朋友可以參考下2014-04-04