[解決済み] JavascriptのJSON比較/差分?
2022-03-06 18:04:15
質問
以下の2つのjsonオブジェクトがあるとします。
JSON A:
{
"Field A":"1",
"Field B":"2",
"Field D":"Something",
"Field E":"6"
}
JSON B:
{
"Field A":"1",
"Field B":"2",
"Field C":"3",
"Field D":"Different"
}
サンプル関数です。 関数 (jsonstringA, jsonstringB)
例(JSON AとJSON Bをパラメータとして使用した場合)。
を含む新しいJSONオブジェクトを返します。
{
"Field C":"3", // because function sees jsonstringB had no "Field C"
"Field D": "Different" // sees jsonstringB had a different value for "Field D"
}
jsonstringAを比較のベースにしているので、jsonStringBのフィールドがないものと値だけを返していることに注意してください。これが、"フィールドE"とその値が返されない理由です。
変更された値を含むjsonオブジェクトを返す関数を考えるには、可能であればどのような方法があるでしょうか?
私が試したこと 私はチェックしようとしているフィールドを手動で指定して比較を行うことを試みましたが、私は私が非常に非効率的で、私がJSON Bに新しいフィールドを追加するたびに、私が探しているフィールドをハードコードする必要があるため、"Fields"をハードコードしないようにする何かが欲しいのですが...それが私がより苦痛でないものを探しています理由です。
解決方法は?
このような関数を作るのは、それほど難しいことではありません。2番目のオブジェクトの各フィールドをループして、1番目のオブジェクトに存在しないか、値が1番目と異なる場合、そのフィールドをリターンオブジェクトに入れるだけです。
var compareJSON = function(obj1, obj2) {
var ret = {};
for(var i in obj2) {
if(!obj1.hasOwnProperty(i) || obj2[i] !== obj1[i]) {
ret[i] = obj2[i];
}
}
return ret;
};
で実際に見ることができます。 このデモページ .
関連
-
[解決済み】TypeError: 'undefined'はオブジェクトではありません。
-
[解決済み】SyntaxError: ChromeのJavascriptコンソールでUnexpected Identifierが発生する。
-
[解決済み] JavaScriptで "use strict "は何をするのか、その根拠は?
-
[解決済み] JavaScriptで文字列が部分文字列を含むかどうかを確認する方法は?
-
[解決済み] あるJavaScriptファイルを他のJavaScriptファイルにインクルードするにはどうすればよいですか?
-
[解決済み] JavaScriptで文字列をbooleanに変換するにはどうしたらいいですか?
-
[解決済み] JavaScriptでJSONをきれいに印刷する
-
[解決済み] オブジェクトの配列から、プロパティの値を配列として取り出す。
-
[解決済み】JavaScriptの比較では、どちらの等号演算子(== vs ===)を使うべきですか?
-
[解決済み】オブジェクトからプロパティを削除する(JavaScript)
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】Facebook Graph API のクエリで with=location を使用すると "Uncaught (in promise) undefined" というエラーが発生する。
-
[解決済み】React Js: Uncaught (in promise) SyntaxError: 位置 0 の JSON で予期しないトークン < が発生しました。
-
[解決済み】Failed to load resource: net::ERR_FILE_NOT_FOUND loading json.js
-
[解決済み】SyntaxError: ChromeのJavascriptコンソールでUnexpected Identifierが発生する。
-
[解決済み】React-Routerの子が1つしかない。
-
[解決済み】Kendo Observable Bindingと併用する場合、Kendo Switch Labelsを変更することは可能ですか?[Kendo-UI]です。
-
[解決済み】 Uncaught Reference Error: stLight is not defined (in Chrome only)
-
[解決済み】TypeError: AngularJSで未定義のプロパティ'get'を読み取れない
-
[解決済み】JavaScriptで関数が存在するかどうかを確認する方法は?
-
[解決済み] JavaScriptでのオブジェクト比較 [重複]