返回顶部
首页 > 资讯 > 精选 >es6中find()如何用
  • 379
分享到

es6中find()如何用

2023-07-04 11:07:49 379人浏览 安东尼
摘要

这篇文章主要介绍“es6中find()如何用”,在日常操作中,相信很多人在es6中find()如何用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”es6中find()如何用”的疑惑有所帮助!接下来,请跟着小编

这篇文章主要介绍“es6中find()如何用”,在日常操作中,相信很多人在es6中find()如何用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”es6中find()如何用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

在es6中,find()用于通过回调函数查找数组中符合条件的第一个元素的值,语法“array.find(function(...),thisValue)”。find()会为数组中的每个元素都调用一次函数执行,当数组中的元素在测试条件时返回true时,find()返回符合条件的该元素,之后的值不会再调用执行函数;如果没有符合条件的元素返回undefined。

es6 find()的介绍

find() 方法返回通过测试(函数内判断)的数组的第一个元素的值。

find() 方法为数组中的每个元素都调用一次函数执行:

  • 当数组中的元素在测试条件时返回 true 时, find() 返回符合条件的元素,之后的值不会再调用执行函数。

  • 如果没有符合条件的元素返回 undefined

语法:

array.find(function(currentValue, index, arr),thisValue)

参数描述
function(currentValue, index,arr)必需。数组每个元素需要执行的函数。
函数参数:参数描述currentValue必需。当前元素index可选。当前元素的索引值arr可选。当前元素所属的数组对象
thisValue可选。 传递给函数的值一般用 "this" 值。
如果这个参数为空, "undefined" 会传递给 "this" 值

返回值:返回符合测试条件的第一个数组元素值,如果没有符合条件的则返回 undefined。    

注意:

  • find() 对于空数组,函数是不会执行的。

  • find() 并没有改变数组的原始值。

基本使用

Array.prototype.find
返回第一个满足条件的数组元素

const arr = [1, 2, 3, 4, 5];const item = arr.find(function (item) {  return item > 3;});console.log(item);//4

如果没有一个元素满足条件 返回undefined

const arr = [1, 2, 3, 4, 5];const item = arr.find(function (item) {  return item > 5;});console.log(item); //undefined

返回的元素和数组对应下标的元素是同一个引用

const arr = [  {    id: 1,    name: '张三',  },  {    id: 2,    name: '李四',  },  {    id: 3,    name: '王五',  },];const item = arr.find((item) => item.name === '李四');console.log(item);

es6中find()如何用
回调函数的返回值是boolean 第一个返回true的对应数组元素作为find的返回值

const arr = [  {    id: 1,    name: '张三',  },  {    id: 2,    name: '李四',  },  {    id: 3,    name: '王五',  },];const item = arr.find(function (item) {  return item.id > 1;});console.log(item);

es6中find()如何用

回调的参数

当前遍历的元素 当前遍历出的元素对应的下标 当前的数组

const arr = [  {    id: 1,    name: '张三',  },  {    id: 2,    name: '李四',  },  {    id: 3,    name: '王五',  },];const item = arr.find(function (item, index, arr) {  console.log(item, index, arr);});

es6中find()如何用

find的第二个参数

更改回调函数内部的this指向

const arr = [  {    id: 1,    name: '张三',  },  {    id: 2,    name: '李四',  },  {    id: 3,    name: '王五',  },];const item = arr.find(  function (item, index, arr) {    console.log(item, index, arr);    console.log(this);  },  { a: 1 });

es6中find()如何用
如果没有第二个参数
非严格模式下 this -> window

const arr = [  {    id: 1,    name: '张三',  },  {    id: 2,    name: '李四',  },  {    id: 3,    name: '王五',  },];const item = arr.find(function (item, index, arr) {  console.log(item, index, arr);  console.log(this);});

es6中find()如何用
在严格模式下
不传入第二个参数 this为undefined 与严格模式规定相同

'use strict';const arr = [  {    id: 1,    name: '张三',  },  {    id: 2,    name: '李四',  },  {    id: 3,    name: '王五',  },];const item = arr.find(function (item, index, arr) {  console.log(item, index, arr);  console.log(this);});

es6中find()如何用

稀疏数组find

find会遍历稀疏数组的空隙 empty
具体遍历出的值 由undefined占位

const arr = Array(5);arr[0] = 1;arr[2] = 3;arr[4] = 5;const item = arr.find(function (item) {  console.log(item);  return false;});

es6中find()如何用
而ES5数组扩展方法forEach,map,filter,reduce,reduceRight,every,some 只会遍历有值的数组
find的遍历效率是低于ES5数组扩展方法的

find不会更改数组

虽然新增了元素 但是find会在第一次执行回调函数的时候 拿到这个数组最初的索引范围

const arr = [1, 2, 3, 4, 5];const item = arr.find(function (item) {  arr.push(6);  console.log(item);});console.log(arr);

es6中find()如何用

const arr = [1, 2, 3, 4, 5];const item = arr.find(function (item) {  arr.splice(1, 1);  console.log(item);});console.log(arr);

es6中find()如何用
splice 删除对应项 该项位置不保留 在数据最后补上undefined

const arr = [1, 2, 3, , , , 7, 8, 9];arr.find(function (item, index) {  if (index === 0) {    arr.splice(1, 1);  }  console.log(item);});

登录后复制

es6中find()如何用
delete
删除该项的值 并填入undefined

const arr = [1, 2, 3, , , , 7, 8, 9];arr.find(function (item, index) {  if (index === 0) {    delete arr[2];  }  console.log(item);});

es6中find()如何用
pop
删除该项的值 并填入undefined

const arr = [1, 2, 3, , , , 7, 8, 9];arr.find(function (item, index) {  if (index === 0) {    arr.pop();  }  console.log(item);});

es6中find()如何用

创建myFind

Array.prototype.myFind = function (cb) {  if (this === null) {    throw new TypeError('"this" is null');  }  if (typeof cb !== 'function') {    throw new TypeError('Callback must be a function type');  }  var obj = Object(this),    len = obj.length >>> 0,    arg2 = arguments[1],    step = 0;  while (step < len) {    var value = obj[step];    if (cb.apply(arg2, [value, step, obj])) {      return value;    }  }  step++;  return undefined;};

到此,关于“es6中find()如何用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: es6中find()如何用

本文链接: https://lsjlt.com/news/344882.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • es6中find()如何用
    这篇文章主要介绍“es6中find()如何用”,在日常操作中,相信很多人在es6中find()如何用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”es6中find()如何用”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-07-04
  • es6中find()怎么用
    本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。es6 find()的介绍find() 方法返回通过测试(函数内判断)的数组的第一个元素的值。find() 方法为数组中的每个元素都调用一次函数执行:当数...
    99+
    2022-11-22
    ES6 javascript
  • ES6中find()和findIndex()怎么用
    这篇文章主要介绍了ES6中find()和findIndex()怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。find() 和 find...
    99+
    2024-04-02
  • es6中find和filter有哪些区别
    这篇“es6中find和filter有哪些区别”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇...
    99+
    2024-04-02
  • es6中的foreach()如何用
    本篇内容主要讲解“es6中的foreach()如何用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“es6中的foreach()如何用”吧! ...
    99+
    2024-04-02
  • es6中的symbol如何用
    这篇文章主要介绍了es6中的symbol如何用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇es6中的symbol如何用文章都会有所收获,下面我们一起来看看吧。 ...
    99+
    2024-04-02
  • es6中export default如何用
    这篇文章主要介绍了es6中export default如何用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇es6中export default如何用文章都会有所收获,下面我们一...
    99+
    2024-04-02
  • es6中continue如何使用
    这篇“es6中continue如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“es6...
    99+
    2024-04-02
  • es6中let如何使用
    本篇内容介绍了“es6中let如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在es6中,let关键字用于声明变量;但是所声明的变量,...
    99+
    2023-07-04
  • Linux中find命令如何使用
    这期内容当中小编将会给大家带来有关Linux中find命令如何使用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。//find [搜索范围] [搜索条件]// 大小写touch...
    99+
    2023-06-05
  • Linux中如何使用find命令
    小编给大家分享一下Linux中如何使用find命令,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!find的基本语法格式:   &nb...
    99+
    2023-06-13
  • Python中find函数如何使用
    今天小编给大家分享的是Python中find函数如何使用,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。一、find函数的官方定义首先,Python的find函数多用在字符串的处理上,...
    99+
    2023-07-06
  • 在node中如何使用 ES6
    ES6+ 太棒了,但是很多高级功能node是不支持的,就需要使用babel转换成ES5, 1.安装babel依赖 npm install babel-core --save-dev 2.安装babel...
    99+
    2022-06-04
    如何使用 node
  • es6中的proxy如何使用
    本篇内容主要讲解“es6中的proxy如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“es6中的proxy如何使用”吧! 在e...
    99+
    2024-04-02
  • es6中from方法如何用
    今天小编给大家分享一下es6中from方法如何用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下...
    99+
    2024-04-02
  • es6 filter()如何用
    这篇文章主要介绍“es6 filter()如何用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“es6 filter()如何用”文章能帮助大家解决问题。 ...
    99+
    2024-04-02
  • ES6中Object属性如何使用
    本篇文章为大家展示了ES6中Object属性如何使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。我们之前定义对象属性的方法var obj =&...
    99+
    2024-04-02
  • ES6 中Generator 函数如何使用
    ES6 中Generator 函数如何使用,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Generator ...
    99+
    2024-04-02
  • node中如何使用es6/7/8
    这篇文章主要为大家展示了“node中如何使用es6/7/8”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“node中如何使用es6/7/8”这篇文章吧。前言这几年...
    99+
    2024-04-02
  • es6中如何使用反引号
    这篇文章主要为大家展示了“es6中如何使用反引号”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“es6中如何使用反引号”这篇文章吧。 ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作