複製代碼代碼如下:
/*
* List 大小可變數組
* version: 1.0
*/
function List() {
this.list = new Array();
};
/**
* 將指定的元素新增至此清單的尾部。
* @param object 指定的元素
*/
List.prototype.add = function(object) {
this.list[this.list.length] = object;
};
/**
* 將List新增至此清單的尾部。
* @param listObject 一個列表
*/
List.prototype.addAll = function(listObject) {
this.list = this.list.concat(listObject.list);
};
/**
* 傳回此清單中指定位置上的元素。
* @param index 指定位置
* @return 此位置的元素
*/
List.prototype.get = function(index) {
return this.list[index];
};
/**
* 移除此清單中指定位置上的元素。
* @param index 指定位置
* @return 此位置的元素
*/
List.prototype.removeIndex = function(index) {
var object = this.list[index];
this.list.splice(index, 1);
return object;
};
/**
* 移除此清單中指定元素。
* @param object 指定元素
* @return 此位置的元素
*/
List.prototype.remove = function(object) {
var i = 0;
for(; i < this.list.length; i++) {
if( this.list[i] === object) {
break;
}
}
if(i >= this.list.length) {
return null;
} else {
return this.removeIndex(i);
}
};
/**
* 移除此清單中的所有元素。
*/
List.prototype.clear = function() {
this.list.splice(0, this.list.length);
};
/**
* 傳回此清單中的元素數。
* @return 元素數量
*/
List.prototype.size = function() {
return this.list.length;
};
/**
* 傳回清單中指定的start(包括)和end(不包括)之間清單。
* @param start 開始位置
* @param end 結束位置
* @return 新的列表
*/
List.prototype.subList = function(start, end) {
var list = new List();
list.list = this.list.slice(start, end);
return list;
};
/**
* 如果清單不包含元素,則傳回true。
* @return true or false
*/
List.prototype.isEmpty = function() {
return this.list.length == 0;
};