yuheijotaki.com

【学習メモ】JavaScriptコードレシピ集 その15

JavaScriptコードレシピ集 の学習メモ 続きです。

JavaScript コードレシピ集

JavaScript コードレシピ集

Chapter17 プログラムのデバッグ

console.log() しか使ってきませんでしたがいろいろ便利そうです。console.table() とか

251 情報・エラー・警告を出力したい

console.log('ログです');
console.info('情報です');
console.warn('警告です');
console.error('エラーです');

252 オブジェクトの構造を出力したい

console.dir() はオブジェクト構造を出力できる

const item252_myObject = {
  id: 2,
  name: '鈴木'
};
console.dir(item252_myObject);

// body要素の構造を出力
console.dir(document.body);
// baseURI を出力
console.dir(document.body.baseURI); // 結果: http://127.0.0.1:5500/dist/index.html

console.table() はデータが表組みで表示される

const item252_myArray = [
  { id: 100, name: '鈴木', age: 25 },
  { id: 200, name: '田中', age: 30 },
  { id: 300, name: '太郎', age: 35 }
];
console.table(item252_myArray);

254 Error オブジェクトを生成したい

エラーはプログラム実行中に自動で発生する他、開発者側で発生させることも可能です。「エラーを投げる(throw error)」と表現します。関数に不正な値が渡された場合やAPIの戻り値が意図せぬ値になった場合などに使用します。

// Error オブジェクトのインスタンス化
const item254_error = new Error('エラーが発生しました');
console.log(item254_error.message); // 結果: エラーが発生しました

255 エラーを投げたい

API通信時に不正な値が発見されたらエラー扱いにしたいときなどに使用できる

/** 引数value が数値でない場合にエラーを発生させる関数 */
function item255_myFunction(value) {
  if (typeof value !== 'number') {
    // エラーを生成する
    const item255_error = new Error(`「${value}はNumberではありません」`);
    // エラー内容をコンソールで表示する
    console.log(item255_error);
    // エラーを投げる
    throw item255_error;
  }

  console.log(`「${value}」は数値です`);
}

// 関数に数値を渡す(エラーなし)
item255_myFunction(5); // 結果: 「5」は数値です
// 関数に文字列を渡す(エラーが発生する)
item255_myFunction('鈴木'); // 結果: Uncaught Error: 「鈴木はNumberではありません」

256 エラー発生時にエラーを検知したい

コンテンツによってはエラーが発生しても処理を中断せず、続けたい場合もあるでしょう。そのような場合に使うのが try catch です。try {} の部分でエラーが発生すると、catch(error) {} 部分が実行されます。catch(error) {} 部分ではErrorオブジェクトを受けとり、エラー内容の表示などが可能です。

const item256_a = 10;

try {
  item256_a = 20; // aへの再代入 エラー
} catch (error) {
  console.log(`エラーが発生しました: ${error.messsage}`);
}

// 中断されることなく実行される
console.log(`定数item256_aの値は${item256_a}です`); // 結果: 定数item256_aの値は10です

258 エラーの種類について知りたい

種類意味
RangeError値が許容範囲にない
ReferenceError宣言されていない変数を読み出そうとした
SyntaxError言語の構文が不正
TypeErrrorデータ型が不正
URIErrorURIが不正

最後の2章、

  • Chapter 18 関数やクラスについて詳しく知る
  • Chapter 19 JavaScriptをより深く知る

はちょっと発展的な内容なのでスキップします。

まとめ

最後はちょっと飛ばし飛ばしになりましたが、一通り1冊終えることができました。

良かったこととして、

  • JavaScript でできる基本的なことを網羅的に理解ができた。(おそらく)
  • .addEventListener() やアロー関数など、手打ちしていっただの繰り返し書いた記述ものに関しては構文が染み付いた
  • インデントの使い方など、規約的なところでの標準もなんとなく理解できた(それが正でないにしても)

まだまだなこととして、

  • これら学んだ内容を実戦でどの程度使えるようになるのかを具体的に分かっていない

ことがあります。

ともかく1番良かったのは、JavaScript に対しての壁が低く感じれるようになったことでした。