投稿日:2024/10/26 最終更新日:2024/12/07
【JS/TS】個人的に忘れがちなオブジェクトの空判定をする方法
配列が空であるか確認するときは、
if(array.length > 0)
これで分岐させる事ができます。
ではオブジェクトの場合はどうなのか?
書き方
結論、このように書きます。
if(Object.keys(obj).length > 0)
Object.keys(obj)メソッド
Object.keys(obj) は指定されたオブジェクト(objの部分)の列挙可能なプロパティ名を配列として返すJSメソッドです。
下記のように、オブジェクト内の「キー」に当たる部分を全て取得して配列として返してくれます。
const dog = {
// キー: 値
name: "taro",
age: 5,
type: "Shiba Inu",
};
console.log(Object.keys(dog)); // 出力: ["name", "age", "type"]
lengthプロパティを追加
つまり、Object.keys(obj).length
で考えると、Object.keys(dog)
によって["name", "age", "type"]
の配列を取得できていたので、length
プロパティにより3が返されます。なので結果はtrue
となります。
const dog = {
// キー: 値
name: "taro",
age: 5,
type: "Shiba Inu",
};
console.log(Object.keys(dog).length); // 出力: true
よって、このパターン用いることでオブジェクトの空判定を行うことができます。
const dog = {
// キー: 値
name: "taro",
age: 5,
type: "Shiba Inu",
};
if(Object.keys(dog).length > 0) {
console.log("空ではないよ!")
} else {
console.log("空だよ!");
};
// 出力: "空ではないよ!"
どんな場面で使うか?
例えば、APIでデータ取得をするときに活用できます。
REST APIでは基本的にJSON形式でデータを取得しますが、JSONはオブジェクト型になります。
そのため、Object.keys(obj).length > 0
を使うことでfalseであればエラー表示をしたり、表示予定のコンテンツそのものを非表示にするなど最適化を図ることが出来ます。