数组

数组的四个常用方法

push()

  • 该方法可以向数组的末尾添加一个或多个元素,并返回数组的新长度
  • 可以将要添加的元素作为方法的参数传递,这些元素将会自动添加到数组的末尾

pop()

  • 该方法可以删除数组的最后一个元素,并将被删除的元素返回

unshift()

  • 向数组开头添加一个或多个元素,并返回新的数组长度
  • 添加元素后,其他元素的索引会相应调整

shift()

  • 可以删除数组的第一个元素,并将其作为返回值返回

数组的遍历

  • for 循环
var arr = ["张三","李四","王五","马六"];

for(var i=0;i<arr.length;i++){
console.log(arr[i]);
}
  • forEach *
//forEach()  不支持IE9以下浏览器
var arr = ["张三","李四","王五","马六"]; /*
* forEach()方法需要一个函数作为参数
* - 像这种函数,由我们创建但不是我们调用的,我们称之为回调函数
* - 数组中有几个元素就会执行几次,每次执行时,浏览器会将遍历到的元素以实参的形式
* 传递进来,我们可以定义形参,来读取这些内容
* - 浏览器会在回调函数中传递三个参数:
* 第一个参数:当前正在遍历的元素
* 第二个参数:当前正在遍历的元素的索引
* 第三个参数:当前正在遍历的数组
*/ arr.forEach(function(value, index, obj){
console.log(value);
});

slice()和splice()

slice()

  • 可以用来从数组中提取指定元素
  • 参数:截取开始的位置索引,截取结束的位置索引 (前闭后开,第二个参数可以不写,默认取到最后一个元素)
  • 索引可以是负值 -1为最后一个元素

splice()

  • 删除元素并向数组添加新元素
  • 将指定元素从原数组中删除并返回
  • 参数:

    第一个:开始位置索引

    第二个:删除的数量

    第三个及以后:

    可以传递一些新的元素,这些元素会自动插入到开始索引位置之前

数组去重

//创建一个数组
var arr = [1,2,3,2,1,3,4,2,5]; //数组去重1
//获取数组中的每一个元素(遍历)
for(var i=0; i<arr.length; i++){
//遍历当前元素后的所有元素
for(var j=i+1; j<arr.length; j++){
//判断两个元素值是否相等
if(arr[i]==arr[j]){
//相等则证明出现重复,删除j对应元素
arr.splice(j,1);
//当删除了当前j所对应元素后,后面的元素会自动补位
//导致j新对应的元素无法进行比较,如果该元素依旧重复则会遗漏
//故使j自减
j--;
}
}
} console.log(arr);

数组其他方法

/*	1
* concat()可以连接两个或多个数组,并将新的数组返回
* - 该方法不会对原数组产生影响
* - 参数也可以为元素
*/ /* 2
* join()方法可以将数组转换为一个字符串
* - 该方法不会对原数组产生影响,而是将转换后的结果返回
* - 可以指定一个字符串作为参数,它将会作为数组元素的连接符,不填则默认为","
*/ /* 3
* reverse()方法可以用来反转数组
* - 会直接操作原数组
*/ /* 4
* sort()用来对数组元素进行排序
* - 改变原数组
* - 默认按照Unicode编码进行排序,即使对纯数字数组排序一会按照Unicode编码排序
* - 我们可以自己指定排序规则,在sort()添加一个回调函数
* 回调函数中需要定义两个形参
* 浏览器将会分别使用数组中的元素作为实参去调用回调函数
* - 浏览器会根据回调函数的返回值来决定元素的顺序
* 如果返回一个大于0的值,则元素交换位置
* 如果返回一个小于0的值,则元素位置不变
* 如果返回一个0,则认为两个元素相等,不交换位置
*/ var arr = [5,4,2,3,1]; arr.sort(function(a,b){
return a - b; //升序
//return b - a; //降序
});

JavaScript数组的方法 | 学习笔记分享的更多相关文章

  1. JavaScript ES6 数组新方法 学习随笔

    JavaScript ES6 数组新方法 学习随笔 新建数组 var arr = [1, 2, 2, 3, 4] includes 方法 includes 查找数组有无该参数 有返回true var ...

  2. 《零基础学JavaScript(全彩版)》学习笔记

    <零基础学JavaScript(全彩版)>学习笔记 二〇一九年二月九日星期六0时9分 前期: 刚刚学完<零基础学HTML5+CSS3(全彩版)>,准备开始学习JavaScrip ...

  3. javascript数组原型方法

    1.javascript数组原型方法. <!DOCTYPE html> <html lang="en"> <head> <meta cha ...

  4. JavaScript数组归并方法reduce

    示例代码: <!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF ...

  5. 学习笔记分享之汇编---3. 堆栈&标志寄存器

    前言:   此文章收录在本人的<学习笔记分享>分类中,此分类记录本人的学习心得体会,现全部分享出来希望和大家共同交流学习成长.附上分类链接:   https://www.cnblogs.c ...

  6. JavaScript——数组——slice方法

    JavaScript--数组--slice方法 JavaScript中的slice方法类似于字符串的substring方法,作用是对数组进行截取. slice方法有两个参数,indexStart 和 ...

  7. 《JavaScript权威指南》学习笔记 第四天 数组

    昨天学习了js的对象,了解了js的原型链.在js里面万事万物皆对象,只不过一些原始类型要经过包装对象的包装才能暂时变为对象.数组的本质是什么呢?数组其实就是一组数,也就是链表.每个数只是这个链表上的一 ...

  8. 《Javascript权威指南》学习笔记之十二:数组、多维数组和符合数组(哈希映射)

    Array(数组)是JavaScript中较为复杂的数据类型,同Java.C#.VB等程序语言的数组相比.Javascript数组中的元素不必为同样的数据类型,能够在数组每一个元素上混合使用数字.日期 ...

  9. 《JavaScript语言精粹》学习笔记

    一.in的用法 for...in 枚举一个对象的所有可枚举属性 检测DOM/BOM属性 if ("onclick" in elem) { // 元素支持onclick } if ( ...

随机推荐

  1. xcode禁用代码分析的警告和内存泄漏

    在使用xcode进行iphone应用开发时,经常需要添加一些第三方的类库,而一些第三方的类库由于缺少维护,从而导致类库中含有各种警告和各种内存泄漏,但并不影响运行. 倘若我们需要用到第三方库,而由不想 ...

  2. 2018-8-10-win10-uwp-使用动画修改-Grid-column-的宽度

    title author date CreateTime categories win10 uwp 使用动画修改 Grid column 的宽度 lindexi 2018-08-10 19:17:19 ...

  3. oracle函数 sysdate

    [功能]:返回当前日期. [参数]:没有参数,没有括号 [返回]:日期 [示例]select sysdate  hz from dual; 返回:2008-11-5

  4. Knative Tracing 介绍

    摘要: 一个完整的业务实现想要基于 Serverless 模型来开发的话可能会分解成多个 Serverless 模块,每一个模块单独通过 Knative 的 Serving 部署,那么这些不同的 Se ...

  5. Android读取sd卡

    public static String[] getStoragePaths() { List<String> pathsList = new ArrayList<String> ...

  6. Strange Way to Express Integers

    I. Strange Way to Express Integers 题目描述 原题来自:POJ 2891 给定 2n2n2n 个正整数 a1,a2,⋯,ana_1,a_2,\cdots ,a_na​ ...

  7. pytorch bert 源码解读

    https://daiwk.github.io/posts/nlp-bert.html 目录 概述 BERT 模型架构 Input Representation Pre-training Tasks ...

  8. uva 12003 Array Transformer (线段树套平衡树)

    http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...

  9. hdu 1384 Intervals (差分约束)

    Problem - 1384 好歹用了一天,也算是看懂了差分约束的原理,做出第一条查分约束了. 题意是告诉你一些区间中最少有多少元素,最少需要多少个元素才能满足所有要求. 构图的方法是,(a)-> ...

  10. H3C 专线连接模型