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