javascript数组详解
作者:bea
如果你是一个有经验的开发者,你可能会认为这个问题比较简单,但是有的时候,我们会感觉这个问题比较有趣。 首先我们来看看数组的定义:“An array is just a list of values which can be accessed by using an integer as the “key”. The list starts at 0 and goes up from there.”,下面我们用对象来描述数组的定义: 代码如下: var arr = ["b
如果你是一个有经验的开发者,你可能会认为这个问题比较简单,但是有的时候,我们会感觉这个问题比较有趣。
首先我们来看看数组的定义:“An array is just a list of values which can be accessed by using an integer as the “key”. The list starts at 0 and goes up from there.”,下面我们用对象来描述数组的定义:
代码如下:
var arr = ["benjamin", "zuojj"];
//=>
var arr = {
"0": "benjamin",
"1": "zuojj"
};
看上面的例子,总感觉缺少了什么,OK,数组的长度:
代码如下:
var arr = {
"0" : "benjamin",
"1" : "zuojj",
"length" : 2
};
我们知道,在Javascript语言中,数组是一个特殊的对象,我们可以使用访问数组的方式来访问对象的属性,同时,数组也可以像对象那样添加属性。看下例:
代码如下:
var arr = {
"0" : "benjamin",
"1" : "zuojj",
"length" : 2
};
//Outputs: "benjamin"
console.log(arr[0]);
//Outputs: 2
console.log(arr.length);
var arr = ["benjamin", "zuojj"]; arr.url = ""; //Outputs: "" console.log(arr.url); //Outputs: 2 console.log(arr.length);
下面我们来看看数组的方法,数组有很多可操作的方法,如indexOf/slice/splice/sort等,我们知道实际上这些方法存在于Array.prototype中。看下面的例子:
代码如下:
var arr = ["benjamin", "zuojj"];
//Outputs: 1
console.log(arr.indexOf("zuojj"));
arr.indexOf = function(str) {
return "It is customed indexOf!";
}
//Outputs: "It is customed indexOf!"
console.log(arr.indexOf("zuojj"));
事实上,我们可以使用对象重载所有的数组方法。看下面的push方法的例子:
代码如下:
var arr = {
length: 0,
push: function(val) {
//赋值
this[this.length] = val;
//更新数组长度
this.length += 1;
//返回数组长度
return this.length;
}
}
arr.push("zuojj");
arr.push("benjamin");
//Object {0: "zuojj", 1: "benjamin", length: 2, push: function}
console.log(arr);
但是有一个是不能从新实现的,数组的字面量定义:
代码如下:
var arr = ["benjamin", "zuojj"];
但是我们可以使用构造函数来代替:
代码如下:
var arr = new Array("benjamin", "zuojj");
如果不适用字面量定义数组,那么我们可以重定义数组的定义,以我们自己的方式。
代码如下:
var myArr = new CustomArray("benjamin", "zuojj");
现在你知道javascript中数组是如何工作的了吧,希望对大家有所帮助。
有用 | 无用
首先我们来看看数组的定义:“An array is just a list of values which can be accessed by using an integer as the “key”. The list starts at 0 and goes up from there.”,下面我们用对象来描述数组的定义:
代码如下:
var arr = ["benjamin", "zuojj"];
//=>
var arr = {
"0": "benjamin",
"1": "zuojj"
};
看上面的例子,总感觉缺少了什么,OK,数组的长度:
代码如下:
var arr = {
"0" : "benjamin",
"1" : "zuojj",
"length" : 2
};
我们知道,在Javascript语言中,数组是一个特殊的对象,我们可以使用访问数组的方式来访问对象的属性,同时,数组也可以像对象那样添加属性。看下例:
代码如下:
var arr = {
"0" : "benjamin",
"1" : "zuojj",
"length" : 2
};
//Outputs: "benjamin"
console.log(arr[0]);
//Outputs: 2
console.log(arr.length);
var arr = ["benjamin", "zuojj"]; arr.url = ""; //Outputs: "" console.log(arr.url); //Outputs: 2 console.log(arr.length);
下面我们来看看数组的方法,数组有很多可操作的方法,如indexOf/slice/splice/sort等,我们知道实际上这些方法存在于Array.prototype中。看下面的例子:
代码如下:
var arr = ["benjamin", "zuojj"];
//Outputs: 1
console.log(arr.indexOf("zuojj"));
arr.indexOf = function(str) {
return "It is customed indexOf!";
}
//Outputs: "It is customed indexOf!"
console.log(arr.indexOf("zuojj"));
事实上,我们可以使用对象重载所有的数组方法。看下面的push方法的例子:
代码如下:
var arr = {
length: 0,
push: function(val) {
//赋值
this[this.length] = val;
//更新数组长度
this.length += 1;
//返回数组长度
return this.length;
}
}
arr.push("zuojj");
arr.push("benjamin");
//Object {0: "zuojj", 1: "benjamin", length: 2, push: function}
console.log(arr);
但是有一个是不能从新实现的,数组的字面量定义:
代码如下:
var arr = ["benjamin", "zuojj"];
但是我们可以使用构造函数来代替:
代码如下:
var arr = new Array("benjamin", "zuojj");
如果不适用字面量定义数组,那么我们可以重定义数组的定义,以我们自己的方式。
代码如下:
var myArr = new CustomArray("benjamin", "zuojj");
现在你知道javascript中数组是如何工作的了吧,希望对大家有所帮助。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- JavaScript极简入门教程(二):对象和函数
- JavaScript极简入门教程(一):基础篇
- 上传图片预览JS脚本 Input file图片预览的实现示例
- 实用框架(iframe)操作代码
- form.submit()不能提交表单的原因分析
- Google Maps API地图应用示例分享
- 深入分析JQuery和JavaScript的异同
- jquery实现导航固定顶部的效果仿蘑菇街
- 用jquery模仿的a的title属性的例子
- 运用jQuery定时器的原理实现banner图片切换
- 用简洁的jQuery方法toggleClass实现隔行换色
- jQuery实现的导航条切换可显示隐藏
- 原生js和jQuery随意改变div属性style的名称和值
- 一个不错的js html页面倒计时可精确到秒
- js实现select跳转功能代码
- Javascript原型链和原型的一个误区
- Javascript this 关键字 详解
- Javascript 构造函数详解
- Javascript中Array.prototype.map()详解