作者:修成书君4212 | 来源:互联网 | 2024-10-09 18:43
模样如下:Array.prototype.delrepfunction(fun){if(!fun){funfunction(d){returnd;};}varnewArr[];th
模样如下:
Array.prototype.delrep = function(fun) {
if(!fun) {
fun = function(d) {return d;};
}
var newArr = [];
this.sort(function(a, b) {
return fun(a) > fun(b) ? -1 : 1;
});
newArr.push(this[0]);
this.forEach(function(d) {
if(fun(d) != fun(newArr[0])) {
newArr.unshift(d);
}
});
return newArr;
};
1,对于基本类型数组:
[1,2,3,4,5,5,6,6,5].delrep();//输出[1, 2, 3, 4, 5, 6]
2,对于对象数组:
var data = [
{
name: "#",
value: 123
},
{
name: "bbb",
value: 234
},
{
name: "#",
value: 789
}
];
console.log(data2.delrep(function(d) {return d.name;}));
//输出[
{
name: "bbb",
value: 234
},
{
name: "#",
value: 789
}
];
自己写的供大家当工具函数使用,可能会比冒泡排序那种去重要快一些。
其中一点说明的是对于对象数组,参数是一个函数,这个函数返回用来去重的属性。
希望我的文章能帮助到你,更多资料请翻阅d3js.org,
我是朱现明,任职于精硕科技可视化部门前端开发,更多精彩的文章即将奉上.
zhuxianming@admaster.com.cn