㈠数组转字符串

⑴String(arr):将arr中的每个元素转为字符串,用逗号分隔

    固定套路:对数组拍照:用于鉴别是否数组被修改过

⑵arr.join("连接符"):将arr中每个元素转为字符串,用自定义的连接符分隔

// 将字符拼接为单词
var chars = ["H","e","l","l","o"];
console.log(chars.join("")); //Hello

 

⑶固定套路

①将字符组成单词:chars.join("")->  无缝拼接 

扩展:判断数组是空数组:arr.join("")==""

②将单词组成句子:words.join("")

③将数组转化为页面元素的内容:

"<开始标签>"+ 

arr.join("</结束标签><开始标签>") 

+"</结束标签>"

 

㈡拼接和选取

不直接修改原数组,而返回新数组!

⑴拼接

concat()拼接两个或更多的数组,并返回结果

var newArr = arr1.concat(值1,值2,arr2,值3,...)

将值1,值2和arr2中每个元素,以及值3都拼接到arr1的元素之后,返回新数组

其中:arr的元素会被先打散,再拼接

 

var arr1 = [90,91,92];
var arr2 = [80,81];
var arr3 = [70,71,72,73];
var arr4 = arr1.concat(50,60,arr2,arr3); console.log(arr1); //90,91,92 现有数组值不变
console.log(arr4); //90,91,92,50,60,80,81,70,71,72,73

 

⑵选取

slice()返回现有数组的一个子数组

var subArr = arr.slice(starti,endi+1)

选取arr中starti位置开始,到endi结束的所有元素组成新数组返回——原数组保持不变

强调:凡是两个参数都是下标的函数,都有一个特性:

           含头不含尾

 

var arr1 = [10,20,30,40,50];
var arr2 = arr1.slice(1,4);     //20,30,40
var arr3 = arr1.slice(2);      //30,40,50
var arr4 = arr1.slice(-4,-2);   //20,30

console.log(arr1)     //10,20,30,40,50 原数组元素不变

 

⑶选取简写

①一直选取到结尾:可省略第二个参数

②如果选取的元素离结尾近:可用倒数下标:

arr.slice(arr.length-n,arr.length-m+1);

可简写为:arr.slice(-n,-m+1);

③复制数组:

arr.slice(0,arr.length);

可简写为:arr.slice();

 

㈢修改数组

⑴删除

splice 直接修改原数组

arr.splice(starti,n);

删除arr中starti位置开始的n个元素不考虑含头不含尾

其实:var deletes = arr.splice(starti,n);

返回值deletes保存了被删除的元素组成的临时数组

 

var arr1 = [10,20,30,40,50];
var arr2 = arr.splice(2,1);
//var arr2 = arr1.splice(2,2,21,22,23);
//var arr2 = arr1.splice(2,2,[91,92,93]); console.log(arr1);
conlole.log(arr2);

⑵插入

arr.splice(starti,0,值1,值2,...)

在arr中starti位置,插入新值1,值2,...原starti位置的值及其之后的值被向后顺移

 

⑶替换

其实就是删除旧的,插入新的

arr.splice(starti,n,值1,值2,...)

先删除arr中starti位置的n个值,再在starti位置插入新值

强调:删除的元素个数和插入的新元素个数不必一致。

 

㈣颠倒数组

reverse() 颠倒数组中元素的顺序

arr.reverse()

var arr1 = [10,20,30,40,50];
arr1.reverse(); console.log(arr1);

 

强调:仅负责原样颠倒数组,不负责排序

 

㈤排序

将元素按从小到大的顺序重新排列

⑴排序API

arr.sort():默认将所有元素转为字符串再排列

问题:只能排列字符串类型的元素

解决:使用自定义比较器函数

 

⑵排序算法

(手写)冒泡 快速 插入排序

JavaScript的数组API函数的更多相关文章

  1. JavaScript中对数组和数组API的认识

    JavaScript中对数组和数组API的认识 一.数组概念: 数组是JavaScript中的一类特殊的对象,用一对中括号“[]”表示,用来在单个的变量中存储多个值.在数组中,每个值都有一个对应的不重 ...

  2. JavaScript之数组高阶API—reduce()

    一文搞懂JavaScript数组中最难的数组API--reduce() 前面我们讲了数组的一些基本方法,今天给大家讲一下数组的reduce(),它是数组里面非常重要也是比较难的函数,那么这篇文章就好好 ...

  3. JavaScript中常见的数组操作函数及用法

    JavaScript中常见的数组操作函数及用法 昨天写了个帖子,汇总了下常见的JavaScript中的字符串操作函数及用法.今天正好有时间,也去把JavaScript中常见的数组操作函数及用法总结一下 ...

  4. [转] 有趣的JavaScript原生数组函数

    在JavaScript中,可以通过两种方式创建数组,Array构造函数和 [] 便捷方式, 其中后者为首选方法.数组对象继承自Object.prototype,对数组执行typeof操作符返回‘obj ...

  5. JavaScript原生数组函数

    有趣的JavaScript原生数组函数 在JavaScript中,可以通过两种方式创建数组,构造函数和数组直接量, 其中后者为首选方法.数组对象继承自Object.prototype,对数组执行typ ...

  6. 有趣的JavaScript原生数组函数

    本文由 伯乐在线 - yanhaijing 翻译.未经许可,禁止转载!英文出处:flippinawesome.欢迎加入翻译小组. 在JavaScript中,可以通过两种方式创建数组,Array构造函数 ...

  7. JavaScript进阶系列02,函数作为参数以及在数组中的应用

    有时候,把函数作为参数可以让代码更简洁. var calculator = { calculate: function(x, y, fn) { return fn(x, y); } }; var su ...

  8. JavaScript 数组操作函数--转载+格式整理

    JavaScript 数组操作函数(部分)--转载+格式整理 今天看了一篇文章,主要讲的对常用的Js操作函数:push,pop,join,shift,unshift,slice,splice,conc ...

  9. javascript中的所有内容都是一个对象:字符串、值、数组、函数…

    javascript中的所有内容都是一个对象:字符串.值.数组.函数…此外,javascript允许自定义对象.javascript对象JavaScript提供多个内置对象,如字符串.日期.数组等.对 ...

随机推荐

  1. lua编译器和ide

    这里有一个网址,上面记录了大部分流行的LUA开发工具,包括IDE和Editor. http://www.wowwiki.com/Lua_editors 一.Eclipse LDT 1.语法高亮,自动提 ...

  2. Chcp,Chdir(Cd),Chkdsk和Chkntfs

    Chdir(缩写为cd)(全称猜测是change drive):显示或更改当前目录的名称; 注c:a/b\c/d 表示C盘下的a的b的c的d,目录可用' / '(正斜)或 ' \ '(反斜),参数只能 ...

  3. mysql一个SQL案例

    需求 : 测试数据 ),start1 int,end1 int); ,); ,); ,); ,); ,); ,); 解决: 解决2: 解决代码 核心思想,把符合逻辑条件的行,构造相同分组 select ...

  4. MYSQL—第一部分(简介和windows版本的安装)

    一.概述 1.什么是数据库 ? 答:数据的仓库,如:在自己编写的程序中我们创建了一个 db 目录,称其为数据库 2.什么是 MySQL.Oracle.SQLite.Access.MS SQLServe ...

  5. MySQL教程详解之存储引擎介绍及默认引擎设置

    什么是存储引擎? 与其他数据库例如Oracle 和SQL Server等数据库中只有一种存储引擎不同的是,MySQL有一个被称为“Pluggable Storage Engine Architectu ...

  6. Eclipse编写代码时代码自动补全 + 防止按空格自动补全

    都知道Eclipse中的自动补全代码是一个非常好用的工具 如下: 1.Windows——>Preferences——>Java–>Editor–>点击Content Asist ...

  7. 升级降级(期望DP)2019 Multi-University Training Contest 7 hdu杭电多校第7场(Kejin Player)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6656 题意: 有 1~n 个等级,你现在是1级,求升到n级的花费期望.会给你n个条件(i~i+1级升级 ...

  8. C++练习 | 文件流应用(1)

    #include <iostream> #include <cmath> #include <cstring> #include <string> #i ...

  9. win10 64支持承载网络

    在intel官网找到对应型号的网卡驱动. 下载win7版本的,更新驱动.安装完毕之后还要在设备管理里面更新2019 7 30这个版本的驱动. 英特尔® PROSet/无线软件和面向 IT 管理员的驱动 ...

  10. Windows账户管理

    windows账户管理 最近部署人员给我们提了一个需求,就是希望简化部署过程. 为了能够远程桌面控制终端电脑,他们需要为每台终端设置进行一些设置,例如创建用户名和密码,开启允许 远程桌面设置,以及开机 ...