(function() { //Array原型的引用 var arrayProto = Array.prototype, slice = arrayProto.slice, //JS 1.6里面會有原生的forEach方法 _each = arrayProto.forEach; " /> 欧美成人精品三级网站,国产三级a三级三级,亚洲一区精品在线

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

Prototype Array對象 學習

復制代碼 代碼如下:
Array.from = $A;

(function() {
//Array原型的引用    
var arrayProto = Array.prototype,
slice = arrayProto.slice,
     //JS 1.6里面會有原生的forEach方法
_each = arrayProto.forEach; // use native browser JS 1.6 implementation if available

function each(iterator) {
for (var i = 0, length = this.length; i < length; i++)
iterator(this[i]);
}
//如果不是JS1.6,_each設置成對象的each方法
//這里的_each方法是覆蓋了Enuerable里面的_each方法
if (!_each) _each = each;

function clear() {
this.length = 0;
return this;
}

function first() {
return this[0];
}

function last() {
return this[this.length - 1];
}

//返回所有Array內不為null的數據
function compact() {
return this.select(function(value) {
return value != null;
});
}

//把多維數組壓成一維數組
function flatten() {
return this.inject([], function(array, value) {
if (Object.isArray(value))
return array.concat(value.flatten()); //這里有遞歸調用
array.push(value);
return array;
});
}

function without() {
var values = slice.call(arguments, 0);
return this.select(function(value) {
return !values.include(value);
});
}

function reverse(inline) {
return (inline !== false ? this : this.toArray())._reverse();
}

//返回所有Array內不重復的元素,如果數組是有序的,傳入true參數,執行起來會更快
function uniq(sorted) {
return this.inject([], function(array, value, index) {
if (0 == index || (sorted ? array.last() != value : !array.include(value)))
array.push(value);
return array;
});
}

//取兩個數組的交集
function intersect(array) {
return this.uniq().findAll(function(item) {
return array.detect(function(value) { return item === value });
});
}


function clone() {
return slice.call(this, 0);
}

function size() {
return this.length;
}

function inspect() {
return '[' + this.map(Object.inspect).join(', ') + ']';
}

function toJSON() {
var results = [];
this.each(function(object) {
var value = Object.toJSON(object);
if (!Object.isUndefined(value)) results.push(value);
});
return '[' + results.join(', ') + ']';
}

function indexOf(item, i) {
i || (i = 0);
var length = this.length;
if (i < 0) i = length + i;
for (; i < length; i++)
if (this[i] === item) return i;
return -1;
}

function lastIndexOf(item, i) {
i = isNaN(i) ? this.length : (i < 0 ? this.length + i : i) + 1;
var n = this.slice(0, i).reverse().indexOf(item);
return (n < 0) ? n : i - n - 1;
}

function concat() {
var array = slice.call(this, 0), item;
for (var i = 0, length = arguments.length; i < length; i++) {
item = arguments[i];
     //這的第二條件是防止把調用方法的數組元素也一起concat起來
if (Object.isArray(item) && !('callee' in item)) {
for (var j = 0, arrayLength = item.length; j < arrayLength; j++)
array.push(item[j]);
} else {
array.push(item);
}
}
return array;
}

//mixin Enumerable里面的方法
Object.extend(arrayProto, Enumerable);

if (!arrayProto._reverse)
arrayProto._reverse = arrayProto.reverse;

Object.extend(arrayProto, {
_each: _each,
clear: clear,
first: first,
last: last,
compact: compact,
flatten: flatten,
without: without,
reverse: reverse,
uniq: uniq,
intersect: intersect,
clone: clone,
toArray: clone,
size: size,
inspect: inspect,
toJSON: toJSON
});

//這個bug網上沒搜到,誰知道說一下?
var CONCAT_ARGUMENTS_BUGGY = (function() {
return [].concat(arguments)[0][0] !== 1;
})(1,2)

if (CONCAT_ARGUMENTS_BUGGY) arrayProto.concat = concat;

//檢查JS是否原生支持indexOf和lastIndexOf方法,不支持則設置成對象內的方法
if (!arrayProto.indexOf) arrayProto.indexOf = indexOf;
if (!arrayProto.lastIndexOf) arrayProto.lastIndexOf = lastIndexOf;
})();

clear
clone
compact
each
first
flatten
from
indexOf
inspect
last
reduce
reverse
size
toArray
toJSON
uniq
without
下面給出一些方法的例子,簡單的方法就不給出例子了。
flatten():
復制代碼 代碼如下:
['frank', ['bob', 'lisa'], ['jill', ['tom', 'sally']]].flatten()
// -> ['frank', 'bob', 'lisa', 'jill', 'tom', 'sally']


reduce():這個方法的意思就是,如果數字里面有一個數據,這直接返回這個數據,否則返回原來的數組
uniq():
復制代碼 代碼如下:
['Sam', 'Justin', 'Andrew', 'Dan', 'Sam'].uniq();
// -> ['Sam', 'Justin', 'Andrew', 'Dan']

['Prototype', 'prototype'].uniq();
// -> ['Prototype', 'prototype'] because String comparison is case-sensitive


without():
復制代碼 代碼如下:
[3, 5, 6, 1, 20].without(3)
// -> [5, 6, 1, 20]

[3, 5, 6, 1, 20].without(20, 6)
// -> [3, 5, 1]

JavaScript技術Prototype Array對象 學習,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 丁香六月在线观看 | 久久综合九色综合欧洲色 | 4hu四虎永久网址 | 国产午夜精品一区二区 | 依人在线免费视频 | 久久精品久久精品久久精品 | 麻豆91制片厂| 好吊妞视频这里只有精品 | 中文字幕色网站 | 国产精品国产三级国产专不∫ | 午夜黄色大片 | 亚洲另类激情小说 | 欧美人xxxx另类 | 色网在线播放 | 美女网站视频黄色 | 九九久久精品国产 | 国产日韩精品欧美一区喷 | 欧美人人做人人爽人人喊 | 成人午夜视频在线播放 | 四虎4hu永久免费视频大全 | 韩国三级久久精品 | 久久久福利| 成人午夜精品网站在线观看 | 久久久久久网 | 色婷五月 | 国产精品视频一区二区亚瑟 | 亚洲综合色婷婷中文字幕 | 国产免费久久精品丫丫 | 国产亚洲欧洲国产综合一区 | 亚洲图区综合网 | 精品久久久久久久久免费影院 | 国产精品19p | 欧美精品成人久久网站 | 69精品视频| 人和拘一级毛片 | 五月天婷婷精品视频 | www.色天使| 四虎影视国产精品永久在线 | 日本理论午夜中文字幕第一页 | 久久国产乱子伦精品免费不卡 | 91热视频在线观看 |