javascript笔记整理(数组对象)
1、属性
a.length--设置或返回数组元素的数目
- var a=[1,2,3,45,5];
- alert(a.length=6) 结果:6
- alert(a[5]) 结果:undefined
b.constructor--返回构造函数的引用
- var test=new Array();
- alert(test.constructor==Array); true
2、方法
a.删除或添加类
1.push()--向数组的末尾添加一个或更多元素,并返回新的长度
- var a=[1,2,3,4,5];
- alert(a.push('a','b')); 结果:7
- alert(a); 结果:1,2,3,4,5,a,
2.unshift()--向数组的开头添加一个或更多元素,并返回新的长度
- var a=[1,2,3,4,5];
- alert(a.unshift('a','b')); 结果:7
- alert(a); 结果:a,b,1,2,3,4,5
3.pop()--删除数组的最后一个元素,返回删除的元素
- var a=[1,2,3,4,5];
- alert(a.pop()); 结果:5
- alert(a); 结果:1,2,3,4
4.shift()--删除数组的第一个元素,返回删除的元素
- var a=[1,2,3,4,5];
- alert(a.pop()); 结果:1
- alert(a); 结果:2,3,4,5
5.splice(index,num,item1,.....itemX)--删除元素,并向数组添加新元素
index 必需。从何处开始添加或删除,必须是数值类型(数组的下标)
num 必需。规定了删除的个数,如果是0,则不删除
item 可选。需要添加的元素,可以当作替换的元素
如果有删除的元素,返回删除的元素;如果没有删除的元素,返回为空,添加的元素在index值前面
- var a=[1,2,3,4,5];
- alert(a.splice(0,1,'a','b')); 结果:1
- alert(a); 结果:a,b,2,3,4,5
b.数组的转换
join(separator)--将数组分割成字符串
separator可选。指定要使用的分隔符。如果省略该参数,则使用逗号作为分隔符,返回结果就是组合成的字符串
- var a=[1,2,3,4,5];
- alert(a.join('-')); 结果:1-2-3-4-5
c.数组的分割
slice(start,end)--从某个已有的数组返回选定的元素
start:必需。规定从何处开始选取。如果是负数,那么它规定从数组尾部开始算起的位置。也就是说,-1 指最后一个元素,-2 指倒数第二个元素,以此类推。
end:可选。规定从何处结束选取。该参数是数组片断结束处的数组下标。如果没有指定该参数,那么切分的数组包含从 start 到数组结束的所有元素。如果这个参数是负数,那么它规定的是从数组尾部开始算起的元素。
- var a=[1,2,3,4,5];
- alert(a.slice(1,4)); 结果:2,3,4
- alert(a.slice(-4,-1)); 结果:2,3,4
- alert(a.slice(-2)); 结果:4,5
不包括,end值的元素
d.排序(冒泡排序)
sort(sortby) 对数组的元素进行排序
sortby:可选。规定排序顺序。必须是函数。如果没有参数,则按照字母的编码进行排序.
sortby会提供两个参数(a,b)
a<b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值
a=b,则返回 0。
a>b,则返回一个大于 0 的值
- var a=[1,2,3,22,5];
- alert(a.sort()); 结果:1,2,22,3,5
- alert(a.sort(function(a,b){return b-a})); 结果:22,5,3,2,1
- alert(a.sort(function(a,b){return a-b})); 结果:1,2,3,5,22
f.数组的连接
concat()--连接两个或更多的数组,并返回结果,对原数组没有任何影响
- var a=[1,2,3,22,5];
- var b=['a','b','c'];
- alert(a.concat(b)); 结果:1,2,3,22,5,a,b,c
代码实践:
- ----------------冒泡排序--------------
- var a=[34,13,8,22,5];
- function arrsort(){
- for(var i=0;i<=this.length;i++){
- for(var j=0;j<=this.length-1;j++){
- var aa=this[j];
- if(this[j]<this[j+1]){
- this[j]=this[j+1];
- this[j+1]=aa;
- }
- }
- }
- return this;
- }
- Array.prototype.arrSort=arrsort;
- alert(a.arrSort());
- 结果:34,22,13,8,5
- -----------------删除数组的重复元素--------------
- var a=[34,13,22,22,5,'aa','aa'];
- function arrsort(){
- for(var i=0;i<=this.length;i++){
- for(var j=0;j<=this.length-1;j++){
- if(this[j]===this[j+1]){
- this.splice(j,1);
- }
- }
- }
- return this;
- }
- Array.prototype.arrSort=arrsort;
- alert(a.arrSort());
- 结果:34,13,22,5,aa
javascript笔记整理(数组对象)的更多相关文章
- javascript笔记整理(对象遍历封装继承)
一.javascript对象遍历 1.javascript属性访问 对象.属性名 对象['属性名'] var obj={name:'chen',red:function(){ alert(1);ret ...
- javascript笔记整理(对象的继承顺序、分类)
Object.prototype.say=function(){ alert("我是顶层的方法"); } children.prototype=new parent(); pare ...
- javascript笔记整理(对象基础)
一.名词解释 1.基于对象(一切皆对象,以对象的概念来编程) 2.面向对象编程(Object Oriented Programming,OOP) A.对象(JavaScript 中的所有事物都是对象) ...
- 运维开发笔记整理-QueryDict对象
运维开发笔记整理-QueryDict对象 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 客户端发送数据请求有很多种,相信运维人员已经很清楚了,如果不太清楚的话可以参考我之前的学习笔 ...
- 运维开发笔记整理-JsonResponse对象
运维开发笔记整理-JsonResponse对象 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.使用HttpResponse发送json格式的数据 1>.HttpRespo ...
- 运维开发笔记整理-Request对象与Response对象
运维开发笔记整理-Request对象与HttpResponse对象 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.request对象 1>.什么是request 首先,我 ...
- javascript中的数组对象
1.创建数组的三种方式: 1.1 var 数组名=[元素1,元素2,元素3...]; 例如: var arr1=[1,2,3,4]; 1.2 var 数组名=new Array(元素1,元素2,元素3 ...
- javascript:类数组 -- 对象
在javascript中,对象与数组都是这门语言的原生规范中的基本数据类型,处于并列的位置. 类数组:本质是一个对象,只是这个 对象 的属性有点特殊,模拟出数组的一些特性. 一般来说,如果我们有一个 ...
- JavaScript中Array(数组) 对象
JavaScript中Array 对象 JavaScript中创建数组有两种方式 (一)使用直接量表示法: var arr4 = []; //创建一个空数组var arr5 = [20]; // 创建 ...
- JavaScript深入之类数组对象与arguments(转载)
类数组对象 所谓的类数组对象: 拥有一个 length 属性和若干索引属性的对象 举个例子: var array = ['name', 'age', 'sex']; var arrayLike = { ...
随机推荐
- jQuery.form 中的 ajaxForm() 和 ajaxSubmit()
官方例子 http://malsup.com/jquery/form/#ajaxForm官方API http://malsup.com/jquery/form/#api中文API http: ...
- BZOJ 1631: [Usaco2007 Feb]Cow Party
题目 1631: [Usaco2007 Feb]Cow Party Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 491 Solved: 362[Sub ...
- iOS网络之数据请求GET和POST
1. HTTP和HTTPS协议 1> URL URL全称是Uniform Resource Locator(统一资源定位符)通过1个URL,能找到互联网上唯一的1个资源 URL就是资源的地址.位 ...
- SPI通信
SPI是由Motorola公司提出的一种同步串行外围接口:它在速度要求不高,低功耗,需要保存少量参数的智能化传感系统中得到了广泛应用: SPI是一个全双工的同步串行接口,在数据传输过程中,总线上只能是 ...
- [POJ 2588]--Snakes(并查集)
题目链接:http://poj.org/problem?id=2588 Snakes Time Limit: 1000MS Memory Limit: 65536K Description B ...
- USACO March. 2012
Connect the Cows Times17 水题 Landscaping Flowerpot Tractor 广搜 搜到边界就可以终止了 没什么难度 #include <stdio.h&g ...
- vim 小技巧总结
1.v+移动光标可以选中文本. 2.y可以复制已经选中的文本 3.p可以粘贴 复制一行则:yy 复制当前光标所在的位置到行尾:y$ 复制当前光标所在的位置到行首:y^ 复制三行则:3yy,即从当前光标 ...
- QDebug &operator<<出错(根据QString来找,是不得要领的,而是应该根据QString所在的对象来思考)
程序运行后,总是崩溃在这个地方:inline QDebug &operator<<(const QString & t) 我应该用什么办法找出是哪个QString出了问题呢 ...
- ASP.NET MVC 5 学习教程:修改视图和布局页
原文 ASP.NET MVC 5 学习教程:修改视图和布局页 起飞网 ASP.NET MVC 5 学习教程目录: 添加控制器 添加视图 修改视图和布局页 控制器传递数据给视图 添加模型 创建连接字符串 ...
- python _thread模块使用
python关于线程管理的有2个类,_thread(在2.x的版本中叫thread)和threading. # encoding: UTF-8 import thread import time ...