欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js數(shù)組高階函數(shù)之includes()方法總結(jié)

 更新時間:2023年12月06日 14:52:02   作者:小貓娃來啦  
JS的數(shù)組是一種特殊的對象,其特點是在值的列表中按照順序存放值,在 JS中,數(shù)組是由中括號 [] 括起來的數(shù)值序列,本篇文章給大家介紹js數(shù)組高階函數(shù)——includes()方法,感興趣的朋友一起看看吧

前言

?JS的數(shù)組是一種特殊的對象,其特點是在值的列表中按照順序存放值。JS數(shù)組用于存儲按照索引順序排列的數(shù)據(jù),例如數(shù)字、字符串和對象等。數(shù)組是一個類似于列表的高階對象,它可以存儲任何類型的數(shù)據(jù),并且具有一些非常有用的方法。其中,includes()方法是其中最常用的之一。
在 JS中,數(shù)組是由中括號 [] 括起來的數(shù)值序列。數(shù)組可以包含不同類型的值,例如數(shù)字、字符串、對象等。以下是一些基礎(chǔ)的 JS數(shù)組操作:

數(shù)組的一般化操作

創(chuàng)建數(shù)組

let myArray = []; // 創(chuàng)建一個空數(shù)組
let myArray = [1, 2, 3]; // 創(chuàng)建一個包含三個數(shù)值的數(shù)組
let myArray = new Array(); // 用構(gòu)造函數(shù)創(chuàng)建一個空數(shù)組
let myArray = new Array(1, 2, 3); // 用構(gòu)造函數(shù)創(chuàng)建一個包含三個數(shù)值的數(shù)組

獲取數(shù)組長度

 let myArray = [1, 2, 3];console.log(myArray.length); // 輸出 3

訪問(遍歷)數(shù)組元素

let myArray = [1, 2, 3];
console.log(myArray[0]); // 輸出 1
console.log(myArray[1]); // 輸出 2
console.log(myArray[2]); // 輸出 3

修改數(shù)組元素

let myArray = [1, 2, 3];
myArray[1] = 4;
console.log(myArray); // 輸出 [1, 4, 3]

刪除數(shù)組元素

let myArray = [1, 2, 3];
delete myArray[1];
console.log(myArray); // 輸出 [1, 3]

數(shù)組尾部添加

let myArray = [1, 2, 3];
myArray.push(4);
console.log(myArray); // 輸出 [1, 2, 3, 4]

數(shù)組尾部刪除

let myArray = [1, 2, 3];
myArray.pop();
console.log(myArray); // 輸出 [1, 2]

includes()方法

?對于數(shù)組中是否包含某個元素,我們可以使用 includes() 方法。includes() 方法用于判斷數(shù)組中是否包含某個指定的元素,如果包含,則方法返回 true,否則返回 false。

以下是 includes() 方法的語法:

 array.includes(searchElement[, fromIndex])

其中:

searchElement:需要查找的元素,必選。fromIndex:可選,從該索引處開始查找元素。如果省略該參數(shù),則從數(shù)組的頭開始查找。如果 fromIndex 大于或等于數(shù)組長度,則返回 false。

舉例說明

當(dāng)我們使用includes()方法時,可以通過傳入一個元素作為參數(shù)來判斷數(shù)組中是否包含該元素。
???第一例:判斷數(shù)組中是否包含某個數(shù)字

const numbers = [1, 2, 3, 4, 5];
console.log(numbers.includes(3)); 
console.log(numbers.includes(6)); 

在這里插入圖片描述

數(shù)組numbers包含數(shù)字3,因此includes(3)返回true。而數(shù)組numbers不包含數(shù)字6,因此includes(6)返回false。

???第二例:判斷數(shù)組中是否包含某個字符串

const fruits = ['長生界', '神墓', '遮天'];
console.log(fruits.includes('遮天')); 
console.log(fruits.includes('完美世界')); 

在這里插入圖片描述

數(shù)組fruits包含字符串’遮天’,因此includes('banana')返回true。而數(shù)組fruits不包含字符串’grape’,因此includes('grape')返回false。

?????第三例:判斷數(shù)組中是否包含某個對象

const users = [
  { name: '葉天帝', age: 225 },
  { name: '石昊', age: 130 },
  { name: '辰南', age: 135 }
];
const user = { name: '石昊', age: 130 };
console.log(users.includes(user)); // false

在這里插入圖片描述

數(shù)組users包含了一個與user對象相等的對象,但返回的卻是false,為什么呢?

這是因為JavaScript 中的 includes() 方法用于檢查一個數(shù)組是否包含某個特定的元素,它并不適用于檢查對象。因此,在上述代碼中使用 includes() 方法進(jìn)行判斷是不準(zhǔn)確的。
為什么不準(zhǔn)確呢?

因為 includes() 方法在比較對象時使用的是嚴(yán)格相等運算符(===),而不是按對象屬性逐個匹配的方式。
如果想要檢查數(shù)組中是否包含某個對象,可以使用 some() 方法,代碼示例如下:

const users = [
  { name: '葉天帝', age: 225 },
  { name: '石昊', age: 130 },
  { name: '辰南', age: 135 }
];
const user = { name: '石昊', age: 130 };
const isUserIncluded = users.some(u => u.name === user.name && u.age === user.age);
console.log(isUserIncluded); //true

在這里插入圖片描述

關(guān)鍵點

第一點:includes()方法在比較元素時使用的是嚴(yán)格相等(===)的方式。

第二點:如果數(shù)組中有多個相同的元素,includes()方法只會返回第一個匹配到的元素。

第三點:兼容性:
includes() 方法并不兼容所有的瀏覽器。如果需要在不支持 includes() 方法的瀏覽器中使用該方法,可以使用以下 polyfill 實現(xiàn):

if (!Array.prototype.includes) {
    Array.prototype.includes = function(searchElement /*, fromIndex*/ ) {
        'use strict';
        var O = Object(this);
        var len = parseInt(O.length) || 0;
        if (len === 0) {
            return false;
        }
        var n = parseInt(arguments[1]) || 0;
        var k;
        if (n >= 0) {
            k = n;
        } else {
            k = len + n;
            if (k < 0) {
                k = 0;
            }
        }
        while (k < len) {
            var currentElement = O[k];
            if (searchElement === currentElement ||
                (searchElement !== searchElement && currentElement !== currentElement)) {
                return true;
            }
            k++;
        }
        return false;
    };
}

在這個 polyfill 中,Array.prototype.includes() 方法首先通過對象來獲取數(shù)組的長度,并使用 while 循環(huán)來遍歷數(shù)組。如果搜索的元素存在則返回 true,否則返回 false。

總結(jié)

細(xì)節(jié)方面:

  • includes() 方法適用于字符串和數(shù)組類型。
  • 它可以快速判斷目標(biāo)對象中是否包含指定的元素。
  • 在字符串中,它區(qū)分大小寫,如果找到完全匹配的子串,返回 true;否則返回 false。
  • 在數(shù)組中,它使用嚴(yán)格相等(===)來匹配元素,如果找到與搜索元素相等的元素,返回 true;否則返回 false。
  • 可以通過第二個參數(shù)來設(shè)置搜索的起始位置或索引。
  • includes() 方法在 ES6 中新增,不支持舊版本的瀏覽器,可以使用 polyfill 或轉(zhuǎn)譯工具進(jìn)行兼容處理。

應(yīng)用場景方面:

檢查字符串是否包含特定子串
可以使用 includes() 方法來檢查一個字符串是否包含了某個子串。例如,判斷一個文章內(nèi)容是否包含特定關(guān)鍵字,并根據(jù)結(jié)果進(jìn)行相應(yīng)處理。

檢查數(shù)組是否包含特定元素
可以使用 includes() 方法來檢查一個數(shù)組中是否包含了某個特定的元素。例如,在一個商品列表中,判斷用戶所選商品是否在購物車中存在。

查找文件名的拓展名
在處理文件路徑時,可以使用 includes() 方法來判斷文件名是否包含特定的拓展名。例如,判斷一個文件是否為圖片文件(如 .jpg、.png 等),便于后續(xù)的處理。

過濾數(shù)組中的特定元素
利用 includes() 方法可以在數(shù)組中快速過濾掉指定的元素。例如,從一個任務(wù)列表中排除已完成的任務(wù),構(gòu)建一個新的未完成任務(wù)列表。

實現(xiàn)輸入提示功能
在前端開發(fā)中,可以使用 includes() 方法對用戶的輸入進(jìn)行匹配和過濾,實現(xiàn)輸入提示或自動補(bǔ)全的功能。例如,根據(jù)用戶輸入的關(guān)鍵詞,展示匹配的選項供選擇或顯示相關(guān)提示信息。

快速判斷字符串是否為空或數(shù)組是否為空
通過使用 includes() 方法判斷字符串是否包含空字符串或數(shù)組是否包含元素,可以快速檢測目標(biāo)對象是否為空。

到此這篇關(guān)于js數(shù)組高階函數(shù)——includes()方法的文章就介紹到這了,更多相關(guān)js includes()方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 郵箱下拉自動填充選擇示例代碼附圖

    郵箱下拉自動填充選擇示例代碼附圖

    這篇文章主要介紹了郵箱下拉自動填充選擇的具體實現(xiàn),需要的朋友可以參考下
    2014-04-04
  • JavaScript中Array功能方法詳解

    JavaScript中Array功能方法詳解

    Array?對象是前端開發(fā)中使用頻率最高的數(shù)據(jù)結(jié)構(gòu)之一,今天我們來復(fù)習(xí)一下它的幾種操作方法,find(),some()和filter(),通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2023-08-08
  • JavaScript設(shè)計模式--簡單工廠模式定義與應(yīng)用案例詳解

    JavaScript設(shè)計模式--簡單工廠模式定義與應(yīng)用案例詳解

    這篇文章主要介紹了JavaScript設(shè)計模式--簡單工廠模式定義與應(yīng)用,結(jié)合具體案例形式詳細(xì)分析了JavaScript設(shè)計模式中簡單工廠模式基本概念、定義、用法與相關(guān)注意事項,需要的朋友可以參考下
    2020-05-05
  • 微信小程序?qū)崿F(xiàn)表單驗證提交功能

    微信小程序?qū)崿F(xiàn)表單驗證提交功能

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)表單驗證提交功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 同時使用n個window onload加載實例介紹

    同時使用n個window onload加載實例介紹

    window onload加載多個同時使用,想必有很多人沒有用過吧,接下來為大家詳細(xì)介紹下具體的使用方法,感興趣的朋友可以參考下
    2013-04-04
  • Js 回車換行處理的辦法及replace方法應(yīng)用

    Js 回車換行處理的辦法及replace方法應(yīng)用

    當(dāng)我們在文本框里輸入文字敲下回車后,希望在提交后網(wǎng)頁也顯示是換行的效果,可往往并不能如愿以償啊,實在是憤怒啊自己寫了一個回車換行處理的函數(shù),感興趣的朋友可以了解下啊,希望本文對你有所幫助
    2013-01-01
  • JS動態(tài)的把左邊列表添加到右邊的實現(xiàn)代碼(可上下移動)

    JS動態(tài)的把左邊列表添加到右邊的實現(xiàn)代碼(可上下移動)

    在javascript前端開發(fā)過程中經(jīng)常見到動態(tài)的把左邊列表添加到右邊,基于js代碼怎么實現(xiàn)的呢?今天小編通過本文給大家介紹下js 左邊列表添加到右邊的實現(xiàn)方法,感興趣的朋友一起看看吧
    2016-11-11
  • Javascript和jquery在selenium的使用過程

    Javascript和jquery在selenium的使用過程

    這篇文章主要介紹了Javascript和jquery在selenium的使用過程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-10-10
  • 使用JavaScript switch case 另類寫法

    使用JavaScript switch case 另類寫法

    在JavaScript里,函數(shù)(todoA、todoB、todoC)就是對象,“()”的作用就是就是執(zhí)行函數(shù)對象,二者簡單地組合一下就能夠讓代碼清晰簡潔很多了,何樂不為呢?
    2010-03-03
  • JavaScript canvas實現(xiàn)雪花隨機(jī)動態(tài)飄落

    JavaScript canvas實現(xiàn)雪花隨機(jī)動態(tài)飄落

    這篇文章主要為大家詳細(xì)介紹了JavaScript canvas實現(xiàn)雪花隨機(jī)動態(tài)飄落,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02

最新評論