js-08-数组学习
一、数组语法格式
var name=[item1,item2,......]
二、数组的声明创建
var arr=new Aarray( ) //声明一个空数组对象
var arr=new Array(length) //声明一个指定长度的数组
var arr=[元素] //声明数组(最常用方法)
注:js中的数组声明不用指定长度,js的数组长度不固定,会随着元素的数量改变而改变。
a:判断是否是数组类型(typeOf arr值为object)
console.log(Array.isArray(xxxx))→ 返回值为true或者false
三、通过for循环遍历数组
for(var i=0;i<arr.length;i++)
alert(arr[i]);
} for-in:
for (var p in fruits){ //遍历数组和对象
document.write(p+'<br>') //p遍历下标,
document.write(fruits[p]+"<br>");
}
四、forEach()方法调用于数组的每个元素,并将元素传递给回调函数。对于空数组是不会执行回调函数的。
//回调函数(callback)是以一个以形参形式传递给另一个函数的函数,并且该函数必须等另一个函数执行完才会被调用
var text = "";
fruits.forEach(myFunction);
document.write(text) ;
function myFunction(value) {
text += value + "<br>";
}
console.log(typeof fruits.forEach);
五、isArray识别数组
var fruits = ["Banana", "Orange", "Apple", "Mango"];
alert(Array.isArray(fruits)); //语法:Array.isArray(obj)
六、toString(将逻辑值转换为字符串,并返回结果)
var fruits = ["Banana", "Orange", "Apple", "Mango"];
document.write(fruits.toString("")+'<br>');
console.log(typeof(fruits)); //类型对象
console.log(typeof(fruits.toString()));//toString转换成字符串
join() 方法也可将所有数组元素结合为一个字符串。
document.write(fruits.join("*")) ;
七、Popping 和 Pushing、shift、unshift、delete、splice、concat、slice
a:pop()方法从数组中删除最后一个元素。
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.pop()
document.write(fruits+'<br>');
//返回被删除的值:Banana,
document.write(fruits.pop()+'<br>');
b:push()方法(在数组结尾处)向数组添加一个新的元素
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.push("Kiwi")
document.write(fruits) ;
//返回push() 方法返回新数组的长度:
document.write(fruits.push("Kiwi")+'<br>') ; //5
c:shift()会删除首个数组元素,并把所有其他元素“位移”到更低的索引。
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.shift();
document.write(fruits+'<br>') ;
console.log(fruits[0]); //Orange
document.write(fruits.shift()+'<br>') ;
d:unshift() 方法(在开头)向数组添加新元素,并“反向位移”旧元素.
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.unshift("lemon")
document.write(fruits+'<br>');
console.log(fruits[0]); //lemon
document.write(fruits.unshift("lemon")) ;//5 unshift() 方法返回新数组的长度
e:delete 运算符来删除,删除元素会在在数组留下未定义的空洞。
var fruits = ["Banana", "Orange", "Apple", "Mango"];
delete fruits[0];
document.write(fruits+'<br>')
console.log("第一种水果是:" + fruits[0]);
f:splice() 方法可以进行添加,删除,替换.
var fruits = ["Banana", "Orange", "Apple", "Mango"];
//第一个参数:定义了应添加新元素的位置(拼接)。
//第二个参数:定义应删除多少元素。
//第三个参数:插入元素
//splice() 方法返回一个包含已删除项的数组
//可以通过splice()替换数组元素
var removed = fruits.splice(1,2, "Lemon", "Kiwi");
document.write("新数组:<br>" + fruits+"<br>");
document.write ( "已删除项:<br> " + removed +"<br>");
//可以通过splice()删除数组元素
var removed = fruits.splice(1,2);
document.write("新数组:<br>" + fruits+"<br>");
//可以通过splice()添加数组元素
var removed = fruits.splice(0,0,"Lemon", "Kiwi");
document.write("新数组:<br>" + fruits+"<br>");
g:concat合并(链接)数组.
var first= [1, 2];
var second= [3, 4, 5];
document.write("第一个数组:"+first+"<br>");
document.write("第二个数组:"+second+"<br>");
var sum= first.concat(second);
document.write( "合并结果:" + sum+"<br>");
var three= [6, 7, 8];
document.write("第三个数组:"+three+"<br>");
var arr4 = first.concat( second,three);
document.write("合并多个数组:" +arr4+"<br>") ;
h:slice() 方法用数组的某个片段切出新数组。/slice() 方法创建新数组。它不会从源数组中删除任何元素。
var fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"];
document.write(fruits + '<br>');
var citrus = fruits.slice(1);//一个参数,从"orange"开始到结尾切出
var citrus = fruits.slice(3);//从"Apple"开始到结尾切出
document.write( citrus + "<br>" );
console.log(citrus[0]);//返回Orange
//slice() 从开始位置到结束位置切出,不包括结束位置。
var citrus = fruits.slice(1,3);
document.write("可接受两个参数" + citrus);//Orange,Lemon
js-08-数组学习的更多相关文章
- js 的概念和声明-js 的变量-js 的运算符和逻辑结构-js 的数组
js 的概念和声明Js的概念和声明:问题:在网页的发展历程中,发现网页不能对用户的数据进行自动校验,和提供一些特效造成用户体验极差解决:使用JavaScript作用:可以让网页和用户之间进行直接简单的 ...
- js数组学习整理
原文地址:js数组学习整理 常用的js数组操作方法及原理 1.声明数组的方式 var colors = new Array();//空的数组 var colors = new Array(3); // ...
- JS数组学习笔记
原文:JS数组学习笔记 最近在备课数组,发现很多ES5的方法平时很少用到.细节比较多,自己做了大量例子和整理,希望对大家了解JavaScript中的Array有所帮助. 概念 数组是值的有序集合.每个 ...
- Knockout.Js官网学习(系列)
1.Knockout.Js官网学习(简介) 2.Knockout.Js官网学习(监控属性Observables) Knockout.Js官网学习(数组observable) 3.Knockout.Js ...
- json2.js的初步学习与了解
json2.js的初步学习与了解,想要学习json的朋友可以参考下. json2.js的初步学习与了解 1.)该js的下载地址是:http://www.json.org/json2.js 2.)在页面 ...
- 原生JS研究:学习jquery源码,收集整理常用JS函数
原生JS研究:学习jquery源码,收集整理常用JS函数: 1. JS获取原生class(getElementsByClass) 转自:http://blog.csdn.net/kongjiea/ar ...
- Underscore.js 源码学习笔记(下)
上接 Underscore.js 源码学习笔记(上) === 756 行开始 函数部分. var executeBound = function(sourceFunc, boundFunc, cont ...
- Underscore.js 源码学习笔记(上)
版本 Underscore.js 1.9.1 一共 1693 行.注释我就删了,太长了… 整体是一个 (function() {...}()); 这样的东西,我们应该知道这是一个 IIFE(立即执行 ...
- js内存深入学习(二)
继上一篇文章 js内存深入学习(一) 3. 内存泄漏 对于持续运行的服务进程(daemon),必须及时释放不再用到的内存.否则,内存占用越来越高,轻则影响系统性能,重则导致进程崩溃. 对于不再用到的内 ...
- js内存深入学习(一)
一. 内存空间储存 某些情况下,调用堆栈中函数调用的数量超出了调用堆栈的实际大小,浏览器会抛出一个错误终止运行.这个就涉及到内存问题了. 1. 数据结构类型 栈: 后进先出(LIFO)的数据结构 堆 ...
随机推荐
- 如何把图片变得炫酷多彩,Python教你这样实现!
有趣的图片 如何能让图片变得好玩?首先需要让它动起来!可如果是多张图片,我们还可以将其拼接起来组成gif动图,可一张图怎么玩?记得之前写过一个小练习,把一张图片拆分成九宫格的分片图.那么,能否由此下手 ...
- es6 babel 安装以及使用
1,安装好node(需要使用npm包管理工具) 2,在本地项目路径下npm init,格式化成功后会在项目下生成一个配置文件package.json 3,本地安装bable npm install - ...
- CollectionView常用的布局方式总结
结合网上的collectionView常用布局整合的collectionView使用工具 下载地址 支持五种布局方式ZFCollectionViewLayoutType有两种ZFCollectionV ...
- iOS Core Animation 简明系列教程
iOS Core Animation 简明系列教程 看到无数的CA教程,都非常的难懂,各种事务各种图层关系看的人头大.自己就想用通俗的语言翻译给大家听,尽可能准确表达,如果哪里有问题,请您指出我会尽 ...
- HashMap的常见问题
关于HashMap的一些常见的问题,自己总结一下: 首选HashMap在jdk1.7和jdk1.8里面的实现是不同的,在jdk1.7中HashMap的底层实现是通过数组+链表的形式实现的,在jdk1. ...
- git 多仓库源 配置
在后台配好ssh公匙后 在C:\Users\Administrator\.ssh 下修改config文件 就叫config不带后缀 若没有则新建 配置SSH 密匙 # 配置github.com Ho ...
- Nginx(二)--nginx的核心功能
反向代理 nginx反向代理的指令不需要新增额外的模块,默认自带proxy_pass指令,只需要修改配置文件就可以实现反向代理. proxy_pass 既可以是ip地址,也可以是域名,同时还可以指定端 ...
- 5G 调制与解调
调制,就是将原始信号转换为适合在信道中传输的形式的一种过程,在无线通信中,调制一般均指载波调制,而解调则是调制的逆过程,即将原始信号从已调信号中恢复出来. 进行载波调制,主要为实现以下目标: 1)在无 ...
- VS Code 成主宰、Vue 备受热捧!2019 前端开发趋势必读
前端在生产和开发中占据着越来越重要的地位,PC 端.手机端.桌面端.智能手表端等等设备都离不开前端的身影.本文将围绕框架.编程语言.工具.React.Vue 等方面,全面回顾 2019 年前端与 We ...
- 网络配置工具iproute2和net-tools的基本原理和基本使用方法
这是网络程序设计课程的第一次作业的博客,由于还是小白,分享的内容都是比较基础的东西,希望看到的各位同学可以提出指导意见,必将虚心听取. 这次分享的内容是网络配置工具iproute2和net-tools ...