Js 数组(一):基础应用
(一) Js 数据类型
分为基本数据类型以及引用类型
基本数据类型有 null,undefined,Boolen,Number,String,还有一种复杂数据类型 Object。
var var1 = "xianrongbin", var2 = false, var3 = null, var4 = undefined, var5 = 123;
console.log(typeof var4); var var6 = [1, 23, 5];
console.log(typeof var6);
这里,其实只需一个var的,为了区别基本数据类型与复杂数据类型,写了两个var 关键字。
将所有的变量定义在一个var后面,有益提升程序运行效率。
如果在一个函数中,不标注 var,则该变量是全局变量,是window的变量,因为所有全局变量都是由window承担的。
function testVar() {
num = 1;
}
testVar();
console.log(window.num);
这里输出1,如果在 "num" 前加上var,输出则会报错。
基本数据类型与值类型,一个是传值,一个是改变地址。
var var6 = [1, 23, 5];
function changeValue(obj) {
obj.pop();
}; changeValue(var6);
console.log(var6); var num = 1;
function changeNum(num) {
num = num + 1;
};
console.log(num);
代码
输出的值是 [1,23] 1。 这点很重要。 这里于C#有很大的不同。
(二) 数组操作
数组类型是Object,数组是值得有序集合。
每个值叫做元素,每个元素在数组中都有数字位置的编号,即索引。
数组是弱类型的,数组中可以含有不同类型的元素。
var arr=[1,'2',[1,2],null]
数组中允许最后面有一个多余的 ‘,’,
var arr1=[,,] --undefined,undefined
1、数组最大长度
最大长度是 2^23-1
2、创建数组
var arr=new Array();
var arrWidthLength=new Array(1000);
var arrLikesLiteral=new Array(1,2,3);
--new 其实是可以省略的
3、数组元素的增删
数组是动态的,无需指定大小
arr[arr.length] --尾部添加一个元素
arr.length-=1 --删除尾部元素
若要 往数组尾添加一个或多个元素,可用push(),
删除最后一个元素,可用pop(),
删除数组头一个元素,可用shif(),
delete arr[2] --第三个元素索引不存在,仍然会存在这个位置,值为undefined
向数组头添加一个或多个元素,可使用unshift,
var testArry = [1, 2, 3, 4, 5, 6];
testArry.push(7); testArry.pop(); testArry.shift(); testArry.unshift('unshift1', 'unshift2'); concatArry= testArry.concat('concat1'); var index = testArry.indexOf('concat1');
testArry.splice(index, 1); testArry.splice(0, 1, 'replace1','replace2');
Array操作基本函数
结果是: ["replace1", "replace2", "unshift2", 2, 3, 4, 5]
4.数组迭代
我们可以使用
for(i in arr) { console.log(arr[i]);
如果我们在数组的prototype添加属性a=‘testa',则输出时也会输出 testa
因此需要判断 if(arr.hasOwnProperty(i)) { }
5.稀疏数组
稀疏数组并不含有从0开始的连续索引,一般length属性值比实际元素个数大。
var arr1=[undefined];
var arr2=new Array(1);
0 in arr1;---true 0 in arr2; ---false
arr1.length=100; arr1[99]=123; 99 in arr1; --true 98 in arr1; --false
6.五个迭代函数
这五个迭代函数是.every .some .filter .forEach .map他们都有三个参数(item,key,value),key是从0开始计数,后两个参数可选用。
. every() 对数组中的每一项运行给定的函数,如果该函数对每一项都返回true,则返回true
. some() 对数组中的每一项运行给定的函数,如果该函数对任意一项返回true,则返回true
. filter() 对数组中的每一项运行给定的函数,返回该函数返回true的项组成的数组,不会影响原函数
. forEach() 对数组中的每一项运行给定的函数,这个方法没有返回值
. map() 对数组中的每一项运行给定的函数,返回每次函数调用的结果组成的数组,不会影响原函数
用法如下
var testArry = [1, 2, 3, 4, 5, 6];
var isAllBig2 = testArry.every(function (item) {
return item > 2;
});
console.log(isAllBig2); var isSomeBig2 = testArry.some(function (item) {
return item > 2;
});
console.log(isSomeBig2); var filterArray = testArry.filter(function (item) {
return item > 2;
});
console.log(filterArray); var mapArray = testArry.map(function (item) {
return item + 2;
});
console.log(mapArray); var forEachResult = testArry.forEach(function (item) {
if (item >5) {
console.log(item);
}
});
其中,.forEach是无返回值,而其他几个是有返回值的,这点需要注意。
上述输出结果分别是
1.Array.prototype.reverse
会对原函数造成逆序
var arr=[1,2,3]; arr.reverse(); arr;---[3,2,1]
2.Array.prototype.sort
是按照字母进行排序的,原数组也会被修改,即改变指针;
arr.sort(function(a,b)){ return a-b; });
3.Array.prototype.contact
contact不会改变原有的数组,只是返回原数组的一个副本。
知道元素的位置后 5.1 需删除某个元素,则使用splice(index,1) ---若省略第二个参数1,表示删除index后面所有的元素
5.2 需要删除某个元素,替换成1个或多个元素,则使用splice(index,1,a,b...),
5.3 需要在某个元素后插入1个或多个元素, 则使用splice(index,0,a,b...)
6. Array.prototype.reduce & reduceRight 数组两两操作,然后返回一个值
var arr=[1,2,3];
var sum=arr.reduce(function(x,y){
retrun x+y;
},0); ---0表示传入的第一个值
7.Array.isArray(..) 判断是否是数组
或者 ... instanceof Array
.constructor===Array
数组是对象,对象不一定是数组,都可以当做对象添加删除属性
数组自动更新length,按索引访问数组常常比访问一般对象属性明显迅速,
数组对象继承Array.prototype上的大量数组操作方法。
Js 数组(一):基础应用的更多相关文章
- JS 数组的基础知识
数组 一.定义 1.数组的文字定义 广义上说,数组是相同类型数据的集合.但是对于强类型语言和弱类型语言来说其特点是不一样的.强类型语言数组和集合有以下特点. 数组强类型语言:1.数组里面只能存放相同数 ...
- 转→js数组遍历 千万不要使用for...in...
看到一篇内容还不错,但是排版实在糟糕, 逼死强迫症患者啊,直接拉下去找原文连接,找到了,但是已经消失了···500错误... 第一次因为实在看不下去一篇博客的排版, 为了排版而转载... 转载地址:h ...
- js数组(列表)的基本操作
本文主要介绍JS对数组(列表)的基本操作.习惯了用数据库的操作顺序来说明:增.删.改.查:合并,裁剪,排序,格式化. 一.数组元素的添加(增加) 增加数组元素有三种方法:unshift() push ...
- javascript数组详解(js数组深度解析)【forEach(),every(),map(),filter(),reduce()】
Array 对象是一个复合类型,用于在单个的变量中存储多个值,每个值类型可以不同. 创建数组对象的方法: new Array(); new Array(size); new Array(element ...
- Angular JS从入门基础 mvc三层架构 常用指令
Angular JS从入门基础 mvc模型 常用指令 ★ 最近一直在复习AngularJS,它是一款优秀的前端JS框架,已经被用于Google的多款产品当中.AngularJS有着诸多特性,最为核心 ...
- js数组操作记录
一 .splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目. arrayObject.splice(index,howmany,item1,.....,itemX) 参数 描述 in ...
- Python数据分析学习(二):Numpy数组对象基础
1.1数组对象基础 .caret, .dropup > .btn > .caret { border-top-color: #000 !important; } .label { bord ...
- js数组方法解析
js 数组有很多方法,其中有的常用,有的不常用,归纳几个常用的方法,做个总结: 1. 转换方法: 1.1 valueOf():调用这个方法会返回数组本身 <script> var arr ...
- 转载收藏(js数组方法大全)
js数组方法大全 JavaScript中创建数组有两种方式 (一)使用 Array 构造函数: var arr1 = new Array(); //创建一个空数组var arr2 = new Arra ...
- js 数组知识复习
2.Array类型 2.1 创建数组 两种方式: 1.new Array(); //创建一个空数组 var arr1 = new Array(); //创建一个长度为10的空数组, var arr2 ...
随机推荐
- 微软发布Win10开发者指南视频
假设你是一个开发者,推荐你看看微软今天推出了一系列视频,标题是Win10开发人员指南,总体长度6时,多达22章内容,介绍很广泛.其实,即使你是编程新手或仅有兴趣,也值得一看. 开发人员Jerry Ni ...
- A + B Again 2057 有符号的64进位的运算
Problem Description There must be many A + B problems in our HDOJ , now a new one is coming.Give you ...
- oracle_自动备份用户数据,删除N天前的旧数据(非rman,bat+vbs)
有时数据没有实时备份恢复那么高的安全性需求,但每天 ,或者定期备份表结构 和数据依旧是很有必要的,介绍一种方法 在归档和非归档模式均可使用的自动备份方法. 预期效果是备份用户下的数据含表结构,备份文件 ...
- 手游开发者大会交流OGEngine新版本发布
由OGEngine第二个手游开发者交流会举办的圆桌会议在深圳市高新技术园区举行.发布会不仅吸引了手游开发商,供应商也纷纷在国外支付,在国内手游和国外出版商参加. 围绕三个主题会议讨论和交流.每个主题: ...
- CodeForces 14 E - Camels && D - Two Paths
D - Two paths 仅仅想到了一个o(n^2)的解法. 首先枚举删除一条边,必定得到两棵独立的树.计算两棵树的直径.保留最大乘积. 首先两条路不相交,则必定能够分到两棵子树中,由于要乘积最大, ...
- 【百度地图API】如何实现信息窗口轮询
原文:[百度地图API]如何实现信息窗口轮询 摘要: 很多微博或者SNS开发者,想结合地图展示用户的微博或者状态.这时,利用信息窗口就是最好的展示方式了. 在这里,我们使用信息窗口轮询的方式来实现这一 ...
- Go as continuous delivery tool for .NET
http://simon-says-architecture.com/2014/02/28/go-as-continuous-delivery-tool-for-net/ Following my p ...
- OC的构造方法与分类知识点总结
OC语言构造方法: 用来初始化对象的方法,对象方法,以减号开头 为了让对象创建出来,成员变量就会有一些固定的值 重写构造方法的注意点: 先调用父类的构造方法([super init]) 再进行子类内部 ...
- TML5安全:CORS(跨域资源共享)简介
来源:http://blog.csdn.net/hfahe/article/details/7730944 前言:像CORS对于现代前端这么重要的技术在国内基本上居然很少有人使用和提及,在百度或者Go ...
- 客户端Webview重定向
今天在客户端的网页中写了句alert的代码,发现执行了两次,后来发现网页的地址写的是http://192.168.14.72/app 客户端Webview加载网页,对于不完全路径会重定向到完全路径,导 ...