Project1
标题:
非常好的数组操作库整理
[打印本页]
作者:
if216
时间:
2018-3-3 17:52
标题:
非常好的数组操作库整理
// 贴这里备忘,分享吧。
// 用法:可以打开任意一个插件,将代码考进去,也可以做成插件,导入插件。然后比如说我要删除一个数组中的元素就[1,2,3].remove(2);就可以了。这个是删完自动改变数组大小的。。。
// 看不懂我再注释。。。
//===========================================================================
// Array
//===========================================================================
Array.prototype.indexOf = function(val) {
for (var i = 0; i < this.length; i++) {
if (this[i] == val) return i;
}
return -1;
};
Array.prototype.remove = function(val) {
var index = this.indexOf(val);
if (index > -1) {
this.splice(index, 1);
}
};
Array.prototype.realLength = function() {
var amount = 0;
for(var i = 0; i < this.length; i++) {
var item = this[i];
if (item && !Number.isNaN(item)) {
amount++;
}
}
return amount;
};
Array.prototype.isEmpty = function() {
return this.length === 0;
};
Array.prototype.needCompact = function() {
return this.contains(null);
};
Array.prototype.compact = function() {
if (!this.needCompact()) {
return this;
}
for(var i = 0; i < this.length; i++) {
if (!this[i]) {
this.splice(i, 1);
return this.compact();
}
}
return this;
};
Array.prototype.insert = function(index, item) {
this.splice(index, 0, item);
};
Array.prototype.count = function(item) {
var amount = 0;
for(var i = 0; i < this.length; i++) {
if (this[i] === item) {
amount++;
}
}
return amount;
};
作者:
梦想家大魔王
时间:
2018-3-3 18:40
原生的js数组操作里面没有移除元素的方法吗?
作者:
ekmomo
时间:
2018-3-8 12:40
本帖最后由 ekmomo 于 2018-3-8 13:32 编辑
我也写俩吧
//去重
Array.prototype.unique =function(){return [...new Set(this)];}
//按值删
Array.prototype.remove = function() {
if (this + ""){
var arg = [...arguments];
while(arg.length){
var val = arg.pop();
this.forEach(function(item, index){
if (item === val) this.splice(index, 1);
}, this);
}
}
return this;
};
欢迎光临 Project1 (https://rpg.blue/)
Powered by Discuz! X3.1