まぶたなしとキムカの答えを組み合わせました。
以下は、angularjsサービスで、数値、文字列、オブジェクトをサポートしています。
exports.Hash = () => {
let hashFunc;
function stringHash(string, noType) {
let hashString = string;
if (!noType) {
hashString = `string${string}`;
}
var hash = 0;
for (var i = 0; i < hashString.length; i++) {
var character = hashString.charCodeAt(i);
hash = ((hash<<5)-hash)+character;
hash = hash & hash; // Convert to 32bit integer
}
return hash;
}
function objectHash(obj, exclude) {
if (exclude.indexOf(obj) > -1) {
return undefined;
}
let hash = '';
const keys = Object.keys(obj).sort();
for (let index = 0; index < keys.length; index += 1) {
const key = keys[index];
const keyHash = hashFunc(key);
const attrHash = hashFunc(obj[key], exclude);
exclude.push(obj[key]);
hash += stringHash(`object${keyHash}${attrHash}`, true);
}
return stringHash(hash, true);
}
function Hash(unkType, exclude) {
let ex = exclude;
if (ex === undefined) {
ex = [];
}
if (!isNaN(unkType) && typeof unkType !== 'string') {
return unkType;
}
switch (typeof unkType) {
case 'object':
return objectHash(unkType, ex);
default:
return stringHash(String(unkType));
}
}
hashFunc = Hash;
return Hash;
};
使用例:
Hash('hello world'), Hash('hello world') == Hash('hello world')
Hash({hello: 'hello world'}), Hash({hello: 'hello world'}) == Hash({hello: 'hello world'})
Hash({hello: 'hello world', goodbye: 'adios amigos'}), Hash({hello: 'hello world', goodbye: 'adios amigos'}) == Hash({goodbye: 'adios amigos', hello: 'hello world'})
Hash(['hello world']), Hash(['hello world']) == Hash(['hello world'])
Hash(1), Hash(1) == Hash(1)
Hash('1'), Hash('1') == Hash('1')
出力
432700947 true
-411117486 true
1725787021 true
-1585332251 true
1 true
-1881759168 true
説明
ご覧のとおり、サービスの中心はKimKhaによって作成されたハッシュ関数です。オブジェクトの構造が最終的なハッシュ値にも影響を与えるように、文字列に型を追加しました。配列|オブジェクトの衝突を防ぐために、キーがハッシュされます。
まぶたのないオブジェクトの比較は、自己参照オブジェクトによる無限再帰を防ぐために使用されます。
使用法
このサービスを作成したのは、オブジェクトでアクセスされるエラーサービスを使用できるようにするためです。そのため、1つのサービスで特定のオブジェクトにエラーを登録し、別のサービスでエラーが検出されたかどうかを判別できます。
すなわち
JsonValidation.js
ErrorSvc({id: 1, json: '{attr: "not-valid"}'}, 'Invalid Json Syntax - key not double quoted');
UserOfData.js
ErrorSvc({id: 1, json: '{attr: "not-valid"}'});
これは戻ります:
['Invalid Json Syntax - key not double quoted']
ながら
ErrorSvc({id: 1, json: '{"attr": "not-valid"}'});
これは戻ります
[]