js操作数组
一、数组的声明方式:
var colors = new Array();//创建数组
var colors = new Array(20);//创建20个长度的数组
var colors = new Array("Greg");//创建字符串数组
var name=[];//空数组
var a = [[1,2],[3,4]];//多维数组
关联数组:
var lennon = Array ();
lennon["name"] = "john";
lennon["year"] = 1940;
lennon["living"] =false;
对象数组:
var a={name:123};
var b={age:456};
var objarr = [a,b];
//输出对象的名和值
alert(Object.keys(objarr[0])+":"+objarr[0].name+","+Object.keys(objarr[1])+":"+objarr[1].age);
读取设置数组的代码示例:
var colors = ["red","blue","green"];//定义一个字符串数组
alert(colors[0]);//显示第一项
colors[2] = "black";//修改第三项
colors[3] = "brown";//新增第四项
注意:
1、var colors = ["red","blue","green"];//创建一个包含3个字符串的数组
colors.length =2;
alert(color[2]); //undefined
2、var colors = ["red","blue","green"];
colors[99] ="black"; //在位置99添加一个颜色,其中3至98都是不存在,取值会报undefined。
alert(colors.length);//100
二、数组检测
1、instanceof
相关示例:
if ( value instanceof Array){//检测值是否为数组
//对数组执行某些操作
}
2 、Array.isArray()是ECMAScript5增加的方法,支持ie9、firefox 4+、safari 5+、opera 10.5+、Chome。
if ( Array.isArray(value)){//检测值是否为数组
//对数组执行某些操作
}
相关示例:
var a = [1, 2, 3];
typeof a;// "object"
Array.isArray(a); // true
上面代码中,typeof运算符只能显示数组的类型是Object,而Array.isArray方法可以对数组返回true。Array.isArray方法用来判断一个值是否为数组。它可以弥补typeof运算符的不足。
三、数组转换
示例一:
var colors = ["red","blue","green"];
alert(colors.tostring()); //red,blue,green
alert(colors.valueof()); //red,blue,green
alert(colors); //red,blue,green
示例二:
var a = [1, 2, 3];
a.valueOf() // [1, 2, 3] valueOf方法返回数组本身。
a.toString() // "1,2,3" 返回数组的字符串形式。
var a = [1, 2, 3, [4, 5, 6]];
a.toString() // "1,2,3,4,5,6"
a.toLocaleString(); //1,2,3 当调用此方法时会创建一个数组值的以逗号分隔的字符串
四、数组的相关操作
1、分割符的使用:
join方法以参数作为分割符,将所有数组成员组成一个字符串返回。如果不提供参数,默认用逗号分割。
相关示例:
var a = [1,2,3,4];
a.john(' '); // '1 2 3 4'
a.john(' | '); // "1 | 2 | 3 | 4"
a.john(); // "1,2,3,4"
如果数组成员是undefined或null或空位,会被转成空字符串。
[undefined, null].join('#') // '#'
['a',, 'b'].join('-') // 'a--b'
通过call方法,这个方法也可以用于字符串。
Array.prototype.join.call('hello', '-') // "h-e-l-l-o"
join方法也可以用于类似数组的对象。
var obj = { 0: 'a', 1: 'b', length: 2 };
Array.prototype.join.call(obj, '-') // 'a-b'
2、增加数组:
1、unshift() 方法向数组的开头添加一个或多个元素,并返回新的长度。 // 注意:会改变原数组
相关示例:
var a = ['a', 'b', 'c'];
a.unshift('x'); // 4
a // ['x', 'a', 'b', 'c']
2、slice()方法
3、
3、删除数组:
4、修改数组:
5、合并数组:
综合示例:
五、数组索引查找
六、数组迭代
七、数组排序
js操作数组的更多相关文章
- JS操作数组的常用方式
一.JS操作数组一:删除指定的元素 splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目. //查找指定元素下标 Array.prototype.indexOf = function ...
- JS操作数组常用的方法
JS操作Array对象的方法 concat(arr1,arr2,...):连接数组indexOf(value):返回数组中value的第一个索引join(separator):将数组中所有的元素连接由 ...
- JS 操作数组对象
我们在操作数组时,加入数组中是以对象的形式存在,例如: 那么我们会涉及到去重复,去掉为0的数组中的对象,js代码如下: function getItemList(gid, totalMoney, ad ...
- js操作数组元素
一, 删除数组指定的某个元素 首先可以给JS的数组对象定义一个函数,用于查找指定的元素在数组中的位置,即索引,代码为: Array.prototype.indexOf = function(val) ...
- js操作数组的一些小技巧
1.从数组中随机获取成员 var items = [12, 548 , 'a' , 2 , 5478 , 'foo' , 8852, , 'Doe' , 2145 , 119]; var rando ...
- js 操作数组封装
function OperateArray(array) { this.array = array; } OperateArray.prototype.hasValue = function(val) ...
- js 操作数组(过滤对应数据)
过滤掉相应数据 var fileList = { "85968439868a92": [{name: 'food.jpeg'}, {name: 'ood.jpeg'}], &quo ...
- JS操作数组-2
1. 找出数组 arr 中重复出现过的元素 function duplicates(arr) { var result = []; var count = []; for (var i=0;i< ...
- 小tips:JS操作数组的slice()与splice()方法
slice(start, end) slice()方法返回从参数指定位置开始到当前数组末尾的所有项.如果有两个参数,该方法返回起始和结束位置之间的项,但不包括结束位置的项. var colors = ...
随机推荐
- ASP.NET:在一般处理程序中通过 Session 保存验证码却无法显示图片?
using System.Drawing; using System.Web; using System.Web.SessionState; /// <summary> /// Captc ...
- 如何搭建DNS服务
继NTP时间服务器后,继续搭建DNS服务,鉴于昨晚撰写时间超过预期,这次改变策略,先把自己需要用到的部分写出来(主要是基于RAC的搭建,只涉及正向和反向DNS解析),后面再添加必要的说明和阐述. 试验 ...
- 怎样录制屏幕并将结果保存为Gif
怎样录制屏幕 并将结果保存为GIF 大前天写文章,需要把PPT的翻转页面截成动态图.我一开始就想到保存文件肯定是GIF.但是如何生成呢?素材又从哪里来?以前自己感兴趣做过把一组连拍的图片做成动态图,再 ...
- java多线程--线程池的使用
程序启动一个新线程的成本是很高的,因为涉及到要和操作系统进行交互,而使用线程池可以很好的提高性能,尤其是程序中当需要创建大量生存期很短的线程时,应该优先考虑使用线程池. 线程池的每一个线程执行完毕后, ...
- Ajax 与 XmlHttpRequest
AJAX描述了确保Web应用在Web服务器请求新数据的情况下也能(几乎)实时反应的一种方法.具体地说,AJAX只是一些建立已久的技术的相互作用,从HTML.XHTML和HTTP,到JavaScript ...
- Android之自定义ViewPager实现图片的无线轮播
PS:以前也写过关于图片轮播这一块的博客.不过写的很烂,并且很多情况没有考虑到(没有支持无线轮播,和手势点击事件).因此这里写一篇补上.也是当时太年轻了. 注:图片请放大后再看.否则看不清楚. 学习内 ...
- jQuery-1.9.1源码分析系列(三) Sizzle选择器引擎——总结与性能分析
Sizzle引擎的主体部分已经分析完毕了,今天为这部分划一个句号. a. Sizzle解析流程总结 是时候该做一个总结了.Sizzle解析的流程已经一目了然了. 1.选择器进入Sizzle( sele ...
- 基于STM32Cube的DAC数模转化
1. STM32Cube配置 1.1 DAC配置 1.2 TIM6 配置 1.3 利用Cube产生工程程序,MDK打开软件 在主循环上添加语句: HAL_TIM_Base_S ...
- jsp原理
在eclipse里jsp编译后的java和class文件的位置 eclipse版本不一样,位置也不一样第一种:1.java类编译后产生的.class文件在D:\workspace\test\WEB-I ...
- 【Win10开发】如何在页面之间传值
我们知道UWP是通过不同的页面来展示不同的内容的,那么我们该怎么进行页面之间的传值呢? 首先我们在MainPage里面写一个ListView来展示一些英文单词. List<English> ...