ウォーターフォールは間違っている!私がアジャイル開発をエンジニアに勧める理由
TypeScriptのexport defaultが非推奨となっていた件
目次
export defaultとは
JavaScriptやTypeScriptでモジュールをエクスポートする方法の1つです。1つのファイルから1つの主要な機能やクラスをエクスポートする際によく使われてきました。
// 従来の書き方
export default function add(a: number, b: number) {
return a + b;
}
なぜ非推奨になったのか
TypeScriptコミュニティで以下の問題点が指摘されています。
・自動インポートやリファクタリングがしづらい
・名前付きエクスポートと比べてバンドルサイズが大きくなりやすい
・デバッグが難しい
・任意の名前でインポートできすぎて混乱を招く
特に自動インポートの問題は深刻でした。VSCodeなどのIDEで自動補完を使う際に、default exportは正しい名前を推測できないことがあります。
推奨される書き方
代わりに名前付きエクスポートを使うことが推奨されています。
// 推奨される書き方
export function add(a: number, b: number) {
return a + b;
}
export class Calculator {
// クラスの実装
}
この書き方なら、インポートする側も明確になります。typoも防げるのでコードの品質が上がりますよ。
移行のコツ
既存のコードを移行する際のポイントです。
- まずは新規コードから名前付きエクスポートを使う
- 既存コードは段階的に移行する
- チーム内でコーディング規約を統一する
- ESLintのルールを設定して自動チェック
一度にすべてを変更する必要はありません。新しいコードから徐々に移行していくのがおすすめです。
まとめ
export defaultは非推奨になりましたが、完全に禁止されているわけではありません。ただし、新しいコードを書く際は名前付きエクスポートを使うことで、より保守性の高いコードが書けます。
チーム開発では特に、名前付きエクスポートを使うことでコードの一貫性が保てて良いですよ。
- 内蔵GPUのRadeon 680M,760MでCS:GO2は動く?|AMD Ryzen 7 6850Hの実力を検証!
- 内蔵GPUのRadeon 680M,760MでCOD BO6は動く?|AMD Ryzen 7 6850Hの実力を検証!
- 内蔵GPUのRadeon 680M,760MでVALORANTは動く?|AMD Ryzen 7 6850Hの実力を検証!
- 内蔵GPUのRadeon 680M,760MでAPEXは動く?|AMD Ryzen 7 6850Hの実力を検証!
- 内臓GPUの性能が良いミニPCをコスパ順でまとめてみた
- TypeScriptで非推奨になっている機能一覧
- TypeScriptのexport defaultが非推奨となっていた件
- TypeScriptのNamespaceが非推奨となっていた件
- TypeScriptのthis.constructorが非推奨となっていた件
- TypeScriptのコンストラクタ引数でのpublic/privateが非推奨となっていた件
- TypeScriptのvarキーワードが非推奨となっていた件
- TypeScriptのFunction型が非推奨となっていた件
- TypeScriptのString, Number, Boolean型が非推奨となっていた件
- TypeScriptのanyが非推奨となっていた件
- TypeScriptのenumが非推奨となっていた件
- 内蔵GPUのメモリ割り当てを増やす方法【2024年版】
- ウォーターフォールは間違っている!私がアジャイル開発をエンジニアに勧める理由
- IT業界の酷い下請け構造は誰のせいなのか
- IT業界の下請け構造が酷すぎる!!
- クラウディアと他のクラウドソーシングサービスの比較
- Zigプログラミング言語とは?RustやC++との違いを解説
- めっちゃ早いPython?Nimというプログラミング言語について
- Rubyの静的型付け版?Crystalってどんな言語なのか解説
- Elixirは開発しづらい?Gleamへ移行しよう – 開発体験が劇的に改善
- Gleamの基本的な構文とデータ型
- Gleamの環境構築方法[Linux]
- Gleam言語でのWebアプリ開発ロードマップ
- MacBook Pro M1の外部ディスプレイちらつき現象について
- MacBook Air M2で4K60Hz外部ディスプレイを使用する方法
- Ryzen 7040HS Phoenix搭載LinuxマシンのGPUドライバー設定ガイド
- 注目を集める新星Gleam言語!Elixirとの違いから見る特徴と可能性
- DellとHP、買うならどっちがマシ?徹底比較ガイド
- サブドメインのメリット・デメリットを徹底解説!
- 中古ドメインって実際どうなの?メリット・デメリットを解説
- ノートパソコン バッテリー持ち ランキング【2024年4月】徹底比較!
- なぜ安い?workドメインが安価な理由を徹底解説!
- メキシコペソ投資ってどうなの?過去データで見る特徴とリスク
- なぜ私がトルコリラ投資をおすすめしないのか – データで見る実態と注意点
- 【2024年4月最新】世界の通貨別金利ランキング!今一番利回りが高い通貨はコレだ!
- 金利5%台!?米ドル保有で高金利を受け取る方法
- axumのルーティングを整理して別ファイルに分ける方法
- Acitx-webとAxumってどっちがいいの?RustのWebフレームワーク比較
- 次期C#?注目のプログラミング言語F#を徹底解説
- 電気ストーブと石油ストーブはどっちがいい?費用や特徴を徹底比較!
- ゲーミングキーボードって正直あんまり変わらないよねって話
- 【2024年版】今後はやるマイナープログラミング言語5選|現役エンジニアが解説
- Rustの現状の課題と発展途上な部分
- 私がRustがC++より優れていると感じる理由
- Rustプログラミング言語完全学習ロードマップ【2024年版】
- おすすめプログラミングスクール比較【2024年版】現役エンジニアが徹底解説