javaScript 基础知识汇总(七)
1、数组
特点:数组是可以存储有序集合的对象。
声明: let arr = new Array();
let arr=[];
大多数情况下我们使用第二种。
let fruits = ["apple","orange","plum"];
fruits[]="Pear";//对数组的更改 fruits[]="Lemon"; 数组元素增加 let arrLength = arr.lenght; //数组的长度
多维数组
let matrix = [
[1, 2, 3],
[4, 5, 6],
[7, 8, 9]
];
alert(matrix[2,1]);//第三行第一个
2、数组的方法
JavaScript中的数组既可以看成栈也可以看成队列
作为队列有以下两种方法:
push 在末端添加一个元素
shift 取出队列最前端的一个元素,整个队列往前移
作为栈有以下两个方法
push 在末端添加一个元素,
pop 在末端取出一个元素
JavaScript 中的数组既可以用作队列,也可以用作栈。它们允许从前端/末端来添加/删除元素。
这在计算机科学中叫做双端队列
//JavaScript在数组末端有两种操作方法
let arr = ["a"];
alert(a.pop());//移除a并显示a arr.push("b");
alert(arr);//b在数组末端添加元素 //在数组前端也有两种方法。
let arr = ["a","b"];
alert(arr.shift());//移除a并显示a
arr.unshift("c");//在数组的前端添加元素。 在数组末端的操作比在数组前端的操作速度要快,因为在数组末端操作不需要更改数据其他位置的索引。
splice
删除数组元素,用delete删除,只能删除该元素的值,但是不能删除元素的索引。
而splic 可以对数组进行添加、删除、和插入操作
语法: arr.splic(index[,deleteCount,elem1,...,elemN])
从index开始:删除deleteCount元素并在当前位置插入elem1,..,elemN。最后返回仪删除元素的数组。
//删除
let arr = ["I", "study", "JavaScript"]; arr.splice(, ); // from index 1 remove 1 element alert( arr ); // ["I", "JavaScript"] //删除并替换 let arr = ["I", "study", "JavaScript", "right", "now"]; // remove 3 first elements and replace them with another
arr.splice(, , "Let's", "dance"); alert( arr ) // now ["Let's", "dance", "right", "now"] //将 deleteCount 设置为 0,splice 方法就能够插入元素而不用删除:
let arr = ["I", "study", "JavaScript"]; // from index 2
// delete 0
// then insert "complex" and "language"
arr.splice(, , "complex", "language"); alert( arr ); // "I", "study", "complex", "language", "JavaScript"
slice
语法:arr.slice(start,end) 赋值数组中的元素
let str = "test";
let arr = ["t", "e", "s", "t"]; alert( str.slice(, ) ); // es
alert( arr.slice(, ) ); // e,s alert( str.slice(-) ); // st
alert( arr.slice(-) ); // s,t
concat
语法:arr.concat(arg1, arg2...)
let arr = [,] alert(arr.concat([,]));//1,2,3,4
查询数组
indexOf/lastIndexOf和includes
这些方法和字符串的一样。
arr.indexOf(item,from) 从索引from 查询item ,如果找到返回索引,否则返回-1;
arr.lastIndexOf(item,from) 从尾部开始查询
arr.includes(item,from) 从索引from 查询iitem 如果找到返回true;
let arr = [,,false]; alert(arr.indexOf());//
alert(arr.indexOf(false));//
alert(arr.indexOf(null));//-1
alert(arr.includes());//true 在这里用的是 === 比较所以如果查询的false ,会精确必须是false,而不是零
find和findIndex
语法:let result = arr.find(function(item,index,array){});
let users =[
{id:1,name:"john"},
{id:2,name:"Pete"},
{id:3,name:"Mary"}
];
let user = users.find(item=>item.id==1);
alert(user.name);//John
filter
和find 类似,但是该方法可以返回多个要素
语法:let result = arr.filter(function(item,index,array){});
let someUsers = users.filter(item=>item.id<3);
alert(someUsers.length);//2
数组转换
map
语法: let result = arr.map(function,index,array){});
对数组中的每一个元素进行判断,最终返回符合结果的数组。
let lengths = ["Bilbo", "Gandalf", "Nazgul"].map(item => item.length)
alert(lengths); // 5,7,6
soft
此方法默认是按照字符串排序的,如果不传参数,返回值不一定是自己想要的
比较函数可以返回任何数字
let arr = [ , , ];
arr.sort(function(a, b) { return a - b; });
alert(arr); // 1, 2, 15
更短的代码
rr.sort( (a, b) => a - b );
reverse
颠倒数组中元素的顺序
let arr = [, , , , ];
arr.reverse(); alert( arr ); // 5,4,3,2,1
split 和join
分割和合并元素
//逗号分割
let names = 'Bilbo, Gandalf, Nazgul'; let arr = names.split(', '); for (let name of arr) {
alert( `A message to ${name}.` ); // A message to Bilbo (and other names)
}
//将一个数组用“;”连接成字符串
let arr = ['Bilbo', 'Gandalf', 'Nazgul']; let str = arr.join(';'); alert( str ); // Bilbo;Gandalf;Nazgul
reduce 和reduceRight
语法:let value = arr.reduce(function(previousValue, item, index, arr) {
// ... }, initial);
previousValue — 是前一个函数调用的结果,第一次调用是初始化。
let arr = [, , , , ]; let result = arr.reduce((sum, current) => sum + current, ); alert(result); //
如果不初始化初始值则默认使用第一个元素作为初始值
let arr = [, , , , ]; // 删除初始值
let result = arr.reduce((sum, current) => sum + current); alert( result ); //
arr.reduceRight 也一样,但是遍历是从右到左。
迭代:forEach
语法:arr.forEach(function(item, index, array) {
// ... do something with item });
// 为每个元素调用 alert
1 ["Bilbo", "Gandalf", "Nazgul"].forEach(alert);
javaScript 基础知识汇总(七)的更多相关文章
- JavaScript基础知识汇总
1. 图片热区: <img src="logo.jpg" usemap="#logo"> <map id="logo" n ...
- javaScript 基础知识汇总(三)
1.循环:while 和 for while 循环 while(condition){ //代码 循环体 } do ... while 循环 let i =0; do { //循环体 }while( ...
- javaScript 基础知识汇总(六)
1.基本类型与对象的区别 基本类型:是原始类型的中的一种值. 在JavaScript中有6中基本类型:string number boolean symbol null undefined 对 ...
- javaScript 基础知识汇总(五)
1.垃圾回收 JavaScript 的内存管理是自动的,不能强制执行或者阻止执行 可达性 JavaScript中主要的内存管理概念是可达性. 什么是可达性? 定义一个对象 let user = { n ...
- javaScript 基础知识汇总(二)
1.运算符 术语或者叫法:一元运算符.二元运算符.运算元(参数) let x=0; x=5+2; //5和2为运算元,“+” 为二元运算符: x=-x; //"-" 为一元运算符 ...
- javascript 基础知识汇总(一)
1.<script> 标签 1) 可以通过<script> 标签将javaScript 代码添加到页面中 (type 和language 属性不是必须的) 2)外部的脚本可以通 ...
- JavaScript 基础知识汇总目录
一.标签.代码结构.现代模式.变量.数据类型.类型转换 GO 二.运算符.值的比较.交互.条件运算符.逻辑运算符 GO 三.循环 while 和 for .switch语句.函数.函数表达式和箭头函数 ...
- javaScript 基础知识汇总 (十三)
1.Class 在JavaScript中 calss即类是一种函数 基本语法 class Myclass{ constructor(){} method1(){} method2(){} method ...
- javaScript 基础知识汇总 (十)
1.New Function 语法:let func = new Function ([arg1[, arg2[, ...argN]],] functionBody) //无参数示例: let say ...
随机推荐
- 如何用Nginx解决跨域问题
一. 产生跨域的原因 1.浏览器限制 2.跨域 3.XHR(XMLHttpRequest)请求 二. 解决思路 解决跨域有多重,在这里主要讲用nginx解决跨域 1.JSONP 2.nginx代理 3 ...
- Nunit说明及简单DEMO
using System; using System.Collections.Generic; using System.Text; using NUnit.Framework; //安装好NUnit ...
- Web of science|SCIE|影响因子|SSCI|高被引论文|领域中热点论文|
信息检索: 数据库 Web of science 影响因子只是针对期刊打分,并不是对文章打分.所以对文章评价可以看引用次数. SCIE (Science Citation Index Expanded ...
- HTMLTestRunner测试报告
把测试报告写入文件中,设置报告生成的路径 测试报告名称上添加时间 HTMLTestRunner文件如下,复制即可用,把该文件放在Lib下即可 """ A TestRunn ...
- Shell字符串比较相等、不相等方法小结
#!/bin/sh #测试各种字符串比较操作. #shell中对变量的值添加单引号,爽引号和不添加的区别:对类型来说是无关的,即不是添加了引号就变成了字符串类型, #单引号不对相关量进行替换,如不对$ ...
- spring提供的事务配置--纯注解
spring提供的事务--纯注解 模拟转账业务 ,出错需要事务回滚,没错正常执行 事务和数据库技术都是spring的内置提供的 --------dao包--------------- IAccoun ...
- 初入 Ubuntu 的一些操作 · Lei's blog
查看系统版本 cat /etc/os-release 修改 root 密码 passwd 新建用户 新建用户: adduser username 将新用户加入 sudo 组,这样就可以用 sudo 命 ...
- 吴裕雄--天生自然 PHP开发学习:在centos7操作系统下使用命令安装ThinkPHP 5框架
前提条件是系统已经安装好了php,一般来说安装好的php根目录是:/var/www/html 系统安装composer(我使用的系统是centos7) .使用命令下载 curl -sS https:/ ...
- 将配置好的虚拟机文件导入VMware
第一步:打开VMware Workstation Pro 第二步: 选择文件,图示: 第三步:点击打开,选择配置好的虚拟机文件目录 点击打开就ok了,图示
- Bitstream or PCM?
背景 提问 讨论精选 一 二 三 四 五 最后 电视上同轴输出的做法. 背景 USB通道下播放声音格式为AAC的视频文件,同轴输出设置为Auto,功放没有声音,设置成PCM,有声音. 提问 Auto/ ...