ホームページ  >  記事  >  ウェブフロントエンド  >  js は配列の重複排除を実装し、配列とオブジェクトの内容が同じかどうかを判断します_javascript スキル

js は配列の重複排除を実装し、配列とオブジェクトの内容が同じかどうかを判断します_javascript スキル

WBOY
WBOYオリジナル
2016-05-16 17:11:361138ブラウズ
复制代码代码如下:

/*
*数组元素去重
*/
if(typeof Array.prototype.distinct != "関数"){
Array.prototype.distinct = function(){
this.sort();
for(var i=0;iif($.isPlainObject(this[i]) && $.isPlainObject(this[i 1])){
if(o2o(this[i],this[i 1])){
this.splice(i,1);
}
}else if($.isArray(this[i]) && $.isArray(this[i 1])){
if(a2a(this[i],this[i 1]) )){
this.splice(i,1);
}
}else if(this[i]===this[i 1]){
this.splice(i,1);
}
}
}
}
/*
*比较对オブジェクトが同じかどうか
*/
function o2o(o1,o2){
if( !($.isPlainObject(o1) && $.isPlainObject(o2))){
return false;
}

var k1k2=[],k1 =[],k2=[];
$.each(o1,function(k,v){
k1.push(k);
});

$.each(o2,function(k,v){
k2.push(k);
});
if(k1.length != k2.length){
return false;
}
k1k2 = k1;
k1k2 = k1k2.concat(k2);
k1k2.distinct();
if(k1.length != k1k2.length || k2.length != k1k2.length){
return false;
}

var flag=true;
$.each(k1k2,function(i,v){
var v1= o1[v];
var v2 =o2[v];
if(typeof v1 != typeof v2) {
flag= false;
}else{
if($.isPlainObject(v1) && $.isPlainObject(v2)){//recursion
flag = o2o(v1,v2); 🎜>if(!flag){
return false;
}
}else if($.isArray(v1) && $.isArray(v2)){
flag = a2a(v1,v2) );
if(!flag){
return false;
}
}else{
if(v1 !== v2){
flag= false;
}
}
});
リターンフラグ;
}
/*
*比较数组かどうか完全に同じ
*/
function a2a(a1,a2){
if(!($.isArray(a1) && $. isArray(a2))){
return false;
}
if(a1.length != a2.length){
return false;
}

a1.sort();
a2.sort();
for(var i=0;iif(typeof a1[i] != typeof a2[i]){
return false;
}
if($.isPlainObject(a1[i]) && $.isPlainObject(a2[i])){
var retVal = o2o(a1[i],a2[i]);
if(!retVal){
false を返します。
}
}else if($.isArray(a1[i]) && $.isArray(a2[i]) ){//再帰
if(!a2a(a1[i],a2[ i])){
false を返します。
}
}else if(a1[i] !== a2[i]){
return false;
}
}
true を返します。
}

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。