草庐IT

工作中需知道的数组方法总结

浮云_cloud 2023-03-28 原文
数组遍历操作
  • forEach 该方法等同于for循环,其没有返回值
    结构:arr.forEach(回调函数,回调函数this的值) 第二个参数当回调函数是箭头函数时无效
用法:
arr.forEach(function(item,index,arr){
// 里面的function是一个回调函数
// item: 数组中的每一项
// index:item 对应的下标索引值
// arr: 就是调用该方法的数组本身
});
  • map 该方法使用和forEach大致相同,该方法有返回值,返回一个新数组,工作中需要对数组的每一项进行操作获取操作后的新数组时可以使用此方法
    结构:arr.map(回调函数,回调函数this的值)
用法:
const arr = [1,2,3];
const newArr= arr.map((item,index,arr) => {
return item * 2;
});
console.log(newArr); // [2,4,6]
console.log(arr); // [1,2,3]
注:当数组元素类型为引用类型时会改变原数组,因为值类型入参是复制,引用类型是指向同一对象
const arr2 = [{num:1},{num:2},{num:3}];
const newArr2 = arr2.map((item,index,arr) => {
item.num2 = 10;
return item;
});
console.log(newArr2); // [{num: 1, num2: 10},{num: 2, num2: 10},{num: 3, num2: 10}]
console.log(arr2); // [{num: 1, num2: 10},{num: 2, num2: 10},{num: 3, num2: 10}]
  • filter 该方法有返回值,返回一个符合条件元素组成的新数组,工作中需要过滤出符合条件的数组元素时可以使用此方法
    结构:arr.filter(回调函数,回调函数this的值)
用法:
const arr = [1,2,3];
const newArr= arr.filter((item,index,arr) => {
return item > 2;
});
console.log(newArr); // [3]
  • some 该方法判断数组中有没有符合条件的项(只要有,就返回true),如果一个都没有才返回false,原理类似于或运算
    结构:arr.some(回调函数,回调函数this的值)
用法:
const arr = [1,2,3];
const flag = arr.some((item,index,arr) => {
return item > 2;
});
console.log(flag); // true
const flag2= arr.some((item,index,arr) => {
return item > 4;
});
console.log(flag2); // false
  • every 该方法判断数组中所有的项是否满足要求,如果全都满足才返回true,否则返回false,原理类似于与运算
    结构:arr.every(回调函数,回调函数this的值)
用法:
const arr = [1,2,3];
const flag = arr.every((item,index,arr) => {
return item > 0;
});
console.log(flag); // true
const flag2= arr.every((item,index,arr) => {
return item > 1;
});
console.log(flag2); // false
数组增删改操作
  • push 该方法可以在数组的最后面增加一个或多个元素,返回值为添加新元素后数组的长度
    结构:arr.push(值)
例:
const arr = [1,2,3];
const arrLength = arr.push(4,5,6);
console.log(arr); // [1,2,3,4,5,6]
console.log(arrLength); // 6
  • pop 该方法为删除数组的最后一位元素,返回值为删除的那个元素
    结构:arr.pop()
例:
const arr = [1,2,3];
const arrLength = arr.pop();
console.log(arr); // [1,2]
console.log(arrLength); // 3
  • unshift 该方法可以在数组的最前面增加一个或多个元素,返回值为添加新元素后数组的长度
    结构:arr.unshift(值)
例:
const arr = [1,2,3];
const arrLength = arr.unshift(0);
console.log(arr); // [0,1,2,3]
console.log(arrLength); // 4
  • shift 该方法为删除数组第一位元素,返回值为删除的元素
    结构:arr.shift()
例:
const arr = [1,2,3];
const arrLength = arr.shift();
console.log(arr); // [2,3]
console.log(arrLength); // 1
  • splice 该方法可以实现删除或增加或替换元素(任意在任何位置,直接改变原数组,没有返回值)
    结构:arr.splice(开始下标位置,处理的个数,新增的元素1,新增的元素2...)
例:
const arr = [1,2,3,4,5,6];
arr.splice(0,2); // 纯删除
console.log(arr); // [3,4,5,6];
arr.splice(1,1,7); // 替换
console.log(arr); // [3,7,5,6]
arr.splice(1,0,8,9); // 纯添加
console.log(arr); // [3,8,9,7,5,6]
检查数组是否包含某个元素
  • includes 该方法可直接检测数组中是否包含某个元素,包含则返回true,不包含则返回false
    结构:arr.includes(值,从某个下标开始)
例:
const arr = [1,2,3];
const flag1 = arr.includes(2);
const flag2 = arr.includes(4) ;
const flag3 = arr.includes(2,2);
console.log(flag1); // true
console.log(flag2); // false
console.log(flag3); // false
  • indexOf 该方法可检测数组中是否包含某个元素,包含则返回第一个匹配元素的索引,不包含则返回-1
    结构:arr.indexOf(值,从某个下标开始)
例:
const arr = [1,2,3,5,2];
const flag1 = arr.indexOf(2);
const flag2 = arr.indexOf(4) ;
const flag3 = arr.indexOf(2,2);
console.log(flag1); // 1
console.log(flag2); // -1
console.log(flag3); // 4
  • lastIndexOf 该方法可检测数组中是否包含某个元素,包含则返回元素的最后一个索引,不包含则返回-1
    结构:arr.lastIndexOf(值,从某个下标开始)
例:
const arr = [1,2,3,4,2,5,6,2];
const flag1 = arr.lastIndexOf(2);
const flag2 = arr.lastIndexOf(9);
console.log(flag1); // 7
console.log(flag2); // -1
数组拼接与截取
  • join 该方法可以将数组里的元素,通过指定的分隔符,以字符串的形式拼接起来,默认是以,分割
    结构:arr.join(分隔符)
例:
const arr = [1,2,3];
const str1 = arr.join();
const str2 = arr.join('-');
console.log(str1); // 1,2,3
console.log(str2); // 1-2-3
  • concat 该方法可以把两个数组里的元素拼接成一个新的数组
    结构:arr.concat(值1, 值2)
例:
const arr1 = [1,2,3];
const arr2 = [4,5,6];
const arr = arr1.concat(arr2,7,8,[9,10]);
console.log(arr) //[1,2,3,4,5,6,7,8,9,10];
  • slice 该方法可以从数组中截取指定的元素段,返回出来,不改变原数组,入参都是可选参数
    结构:arr.slice(开始位,结束位)
例:
const arr = [1,2,3,4,5,6];
const arr1 = arr.slice(); //截取全部
const arr2 = arr.slice(2); //开始位开始往后截取全部
const arr3 = arr.slice(2,5); //开始位开始,不包括结束位元素
console.log(arr1); //[1,2,3,4,5,6]
console.log(arr2); //[3,4,5,6]
console.log(arr3); //[3,4,5]
数组的翻转与排序
  • reverse 该方法将数组中元素的位置颠倒,并返回该数组,会改变原数组
    结构:arr.reverse()
例:
const arr = [1,2,3];
arr.reverse()];
console.log(arr); // [3,2,1]
  • sort 该方法对数组的元素进行排序,并返回数组
    结构:arr.sort(函数)
例:
const arr = [1,5,2,6,9,7,3];
arr.sort(); // 默认排序,会将元素转换为字符串,然后比较它们的 UTF-16 代码单元值实现排序
console.log(arr); // [1, 2, 3, 5, 6, 7, 9]
const arr1 = [1,5,2,6,9,7,3];
arr1.sort((a, b) => { return a - b }); // 自定义排序,递增
console.log(arr1); // [1, 2, 3, 5, 6, 7, 9]
const arr2 = [1,5,2,6,9,7,3];
arr2.sort((a, b) => { return b - a }); // 自定义排序,递减
console.log(arr2); // [9, 7, 6, 5, 3, 2, 1]

有关工作中需知道的数组方法总结的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  3. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  4. ruby - Facter::Util::Uptime:Module 的未定义方法 get_uptime (NoMethodError) - 2

    我正在尝试设置一个puppet节点,但ruby​​gems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由ruby​​gems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby

  5. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  6. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  7. ruby-on-rails - 在 Ruby 中循环遍历多个数组 - 2

    我有多个ActiveRecord子类Item的实例数组,我需要根据最早的事件循环打印。在这种情况下,我需要打印付款和维护日期,如下所示:ItemAmaintenancerequiredin5daysItemBpaymentrequiredin6daysItemApaymentrequiredin7daysItemBmaintenancerequiredin8days我目前有两个查询,用于查找maintenance和payment项目(非排他性查询),并输出如下内容:paymentrequiredin...maintenancerequiredin...有什么方法可以改善上述(丑陋的)代

  8. Ruby 方法() 方法 - 2

    我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby​​-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco

  9. ruby - 多次弹出/移动 ruby​​ 数组 - 2

    我的代码目前看起来像这样numbers=[1,2,3,4,5]defpop_threepop=[]3.times{pop有没有办法在一行中完成pop_three方法中的内容?我基本上想做类似numbers.slice(0,3)的事情,但要删除切片中的数组项。嗯...嗯,我想我刚刚意识到我可以试试slice! 最佳答案 是numbers.pop(3)或者numbers.shift(3)如果你想要另一边。 关于ruby-多次弹出/移动ruby​​数组,我们在StackOverflow上找到一

  10. ruby - 将数组的内容转换为 int - 2

    我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]

随机推荐