javascript Array学习

首先感谢Dash 我再也不用到处乱找文档了

再次感谢日食记 让我的看到了世界的美好

好的 我们进入正题

注解 我所有的学习心得都建立在ECMAscript5之后

IE9之前的浏览器概不负责

javascript Array是一个好玩的对象

如何检测她呢 首先instanceof是个不错的方法

if (value instanceof Array) {
}

不过根据javascript高级程序设计说 这样做 如果一个人重新构造了Array函数 你完了

so 这样

if(Arrays.isArray(value)) {
}


现在我们要构造了

不过搞那些有啥意思呢 

其实我关心这些构造方式时候产生的类型是否一样

var arr1 = [];
var arr2 = new Array();
var arr3 = Array();

alert(typeof arr1);
alert(typeof arr2);
alert(typeof arr3);

好吧 都是object类型 

大家都知道数组里有个length属性 那么她靠谱吗

var fruits = [];
fruits.push('banana', 'apple', 'peach');

console.log(fruits.length); // 3

fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits));  // ['0', '1', '2', '5']
console.log(fruits.length); // 6

卧槽 明明只有4个元素 返回的是6

不过经过我的实验 在现代浏览器(ie9以后版本 chrome firefox safair)上

for (var i = 0; i < fruits.length; i++) {
	console.log(fruits[i]);
};

是会填充undefined的

现在我尝试着修改length属性

fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2

卧槽 我之前的数据呢

查看一下Array.length 居然是可写的

两个作用

  1. 循环数组 类似于foreach

  2. 消除不需要的数组 。。。

Array 实现栈 队列

栈 只有一个出入口 先进后出

so 我们假设现在有一个空数组

var stack = [];

我想要放入 一些元素

var totalnum = stack.push('angel', 'clown', 'mandarin', 'sturgeon');
console.log(stack); // ['angel', 'clown', 'mandarin', 'sturgeon']
console.log(totalnum); // 4

拿出一个元素

var poped = stack.pop();
console.log(poped); // sturgeon

实现一个 队列

队列 先出先进 进出分开

后面进 前面出

var queue = ['angel'];

arr.push('clown', 'mandarin', 'surgeon'); // = 4
console.log('queue before: ' + queue);

var shifted = queue.shift();

console.log('queue after: ' + queue);
console.log('Removed this element: ' + shifted);

前面进 后面出

同样 只是进使用 unshift   出使用pop



你可能感兴趣的:(JavaScript)