ホームページ ウェブフロントエンド jsチュートリアル タイプスクリプトタイプの推論に関する混乱:なぜ4つの関数の返品値タイプの定義が同じであるのか、およびユニオンタイプシナリオのタイプエラーを回避する方法

タイプスクリプトタイプの推論に関する混乱:なぜ4つの関数の返品値タイプの定義が同じであるのか、およびユニオンタイプシナリオのタイプエラーを回避する方法

Apr 04, 2025 pm 03:06 PM
typescript 解決

タイプスクリプトタイプの推論の微妙さを深く探求します:4つの関数のリターン値タイプの定義の等価と、組合タイプの下のタイプ安全性

この記事では、TypeScriptタイプの推論メカニズムを深く分析し、一見異なる関数型定義が同じ結果を取得する方法を説明し、共同タイプシナリオのタイプエラーを解決します。

まず、4種類のgetReturnType定義を観察します。

タイプgetReturnType1<t> = t拡張(... args:never)=> very r? R:決して;
タイプgetReturnType2<t> = t拡張(... args:never [])=> r? R:決して;
タイプgetReturnType3<t> = t extends(... args:any [])=>推測r? R:決して;
タイプgetReturnType4<t> = t拡張(... args:any)=> vert r? R:決して;</t></t></t></t>
ログイン後にコピー

4つのタイプ定義はすべて、関数タイプから戻り値タイプを抽出するように設計されています。パラメータータイプ( never never[] 、[]、 any[]any )は異なりますが、推論のタイプの戻り値タイプRの推論結果に影響はありません。 extendsキーワードは、特定のタイプのパラメーターではなく、関数タイプの構造に焦点を当てています。関数タイプが一致する限り、 infer R戻り値のタイプを正しく推測できます。したがって、これらの4つの定義は実際に同等です。

次に、組合タイプと条件付きタイプが組み合わされたときに発生する可能性のあるタイプエラーを示すコードを分析します。

タイプ小道具<t extends major rescategorylabel> = {
  ラベル:t [];
  setSelect:(index:number、label:t extends major?major:rescategorylabel)=> void;
  xxx:any; //その他の属性は省略されています};

const changeselect =(
  インデックス:番号、
  ラベル:メジャー| RecategoryLabel、
  E:React.MouseEvent<htmlanchorelement> | React.touchevent<htmlanchorelement>
)=> {
  setSelect(index、label);
  ActiveTabTocenter(e.currentTarget as htmlelement);
};</htmlanchorelement></htmlanchorelement></t>
ログイン後にコピー

Propsタイプ定義のsetSelect関数パラメーターlabelのタイプ推論には問題があります。条件付きタイプT extends Major ? Major : ResCategoryLabel Tのタイプに基づいてlabelのタイプを決定しようとします。ただし、 Tは共同タイプのMajor | ResCategoryLabelTの実際のタイプが不明の場合、コンパイラはTMajorResCategoryLabelかを決定することができず、 labelのタイプの推論が失敗します。問題は、条件付きタイプ自体ではなく、組合タイプのコンテキストでの適用です。

解決策は、 Major | ResCategoryLabelを使用することですlabelのタイプとして直接Major | ResCategoryLabel

タイプ小道具<t extends major rescategorylabel> = {
  ラベル:t [];
  setSelect:(index:number、label:major | rescategorylabel)=> void;
  xxx:any; //その他の属性は省略されています};</t>
ログイン後にコピー

このようにして、 setSelect関数のパラメータータイプは明確であり、タイプエラーを回避し、コードの読みやすさと保守性を向上させます。これは、より明確で安全なタイプの定義と引き換えに共同タイプを扱う際に、条件付きタイプによってもたらされる洗練されたタイプの制御を放棄する必要性を反映しています。

タイプスクリプトタイプの推論に関する混乱:なぜ4つの関数の返品値タイプの定義が同じであるのか、およびユニオンタイプシナリオのタイプエラーを回避する方法

以上がタイプスクリプトタイプの推論に関する混乱:なぜ4つの関数の返品値タイプの定義が同じであるのか、およびユニオンタイプシナリオのタイプエラーを回避する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

会社のセキュリティソフトウェアはアプリケーションの実行に失敗していますか?それをトラブルシューティングと解決する方法は? 会社のセキュリティソフトウェアはアプリケーションの実行に失敗していますか?それをトラブルシューティングと解決する方法は? Apr 19, 2025 pm 04:51 PM

一部のアプリケーションが適切に機能しないようにする会社のセキュリティソフトウェアのトラブルシューティングとソリューション。多くの企業は、内部ネットワークセキュリティを確保するためにセキュリティソフトウェアを展開します。 ...

データベースに対するNAVICATのソリューションを接続できません データベースに対するNAVICATのソリューションを接続できません Apr 08, 2025 pm 11:12 PM

次の手順を使用して、NAVICATがデータベースに接続できない問題を解決できます。サーバー接続を確認し、サーバーが実行されていることを確認、アドレス指定、ポートを正しく確認し、ファイアウォールにより接続を許可します。ログイン情報を確認し、ユーザー名、パスワード、許可が正しいことを確認します。ネットワーク接続を確認し、ルーターやファイアウォールの障害などのネットワークの問題をトラブルシューティングします。一部のサーバーでサポートされていない場合があるSSL接続を無効にします。データベースバージョンをチェックして、NAVICATバージョンがターゲットデータベースと互換性があることを確認してください。接続タイムアウトを調整し、リモートまたは遅い接続の場合は、接続タイムアウトタイムアウトを増やします。その他の回避策は、上記の手順が機能していない場合は、別の接続ドライバーを使用してソフトウェアを再起動したり、データベース管理者または公式NAVICATサポートに相談したりすることができます。

Redisメモリの使用量が高すぎる場合はどうすればよいですか? Redisメモリの使用量が高すぎる場合はどうすればよいですか? Apr 10, 2025 pm 02:21 PM

Redisメモリの急上昇には、データ量が大きすぎる、データ構造の選択、構成の問題(Maxmemory設定が小さすぎるなど)、およびメモリリークが含まれます。ソリューションには、期限切れのデータの削除、圧縮技術の使用、適切な構造の選択、構成パラメーターの調整、コードのメモリリークのチェック、およびメモリ使用量の定期的な監視が含まれます。

Centos Minioインストール許可の問題 Centos Minioインストール許可の問題 Apr 14, 2025 pm 02:00 PM

Centos環境にMinioを展開する際のCentosシステムに基づくMinioインストールの許可問題とソリューション、許可の問題は一般的な問題です。この記事では、ミニオのインストールと構成をスムーズに完了するのに役立ついくつかの一般的な許可問題とそのソリューションを紹介します。デフォルトのアカウントとパスワードを変更する:環境変数MINIO_ROOT_USERとMINIO_ROOT_PASSWORDを設定して、デフォルトのユーザー名とパスワードを変更できます。変更後、Minioサービスの再起動が有効になります。バケットアクセス権限の構成:バケットを公開に設定すると、ディレクトリが移動され、セキュリティリスクが発生します。バケットアクセスポリシーをカスタマイズすることをお勧めします。 Minioを使用できます

Centos HDFS構成の一般的な誤解は何ですか? Centos HDFS構成の一般的な誤解は何ですか? Apr 14, 2025 pm 07:12 PM

Hadoop分散ファイルシステム(HDFS)構成の一般的な問題とソリューションは、CentOSにHadoophDFSクラスターを構築する際に、パフォーマンスの劣化、データの損失、さらにはクラスターが開始できない場合があります。この記事では、これらの一般的な問題とそのソリューションをまとめて、これらの落とし穴を回避し、HDFSクラスターの安定性と効率的な動作を確保します。ラックアウェア構成エラー:問題:ラックアウェア情報が正しく構成されていないため、データブロックレプリカの不均一な分布とネットワーク負荷が増加します。解決策:hdfs-site.xmlファイルでラックアウェア構成を再確認し、hdfsdfsadmin-printtopoを使用します

Windows 8でコードを実行できます Windows 8でコードを実行できます Apr 15, 2025 pm 07:24 PM

VSコードはWindows 8で実行できますが、エクスペリエンスは大きくない場合があります。まず、システムが最新のパッチに更新されていることを確認してから、システムアーキテクチャに一致するVSコードインストールパッケージをダウンロードして、プロンプトとしてインストールします。インストール後、一部の拡張機能はWindows 8と互換性があり、代替拡張機能を探すか、仮想マシンで新しいWindowsシステムを使用する必要があることに注意してください。必要な拡張機能をインストールして、適切に動作するかどうかを確認します。 Windows 8ではVSコードは実行可能ですが、開発エクスペリエンスとセキュリティを向上させるために、新しいWindowsシステムにアップグレードすることをお勧めします。

phpmyAdminを使用してMySQLデータベースを作成する方法 phpmyAdminを使用してMySQLデータベースを作成する方法 Apr 10, 2025 pm 10:48 PM

PHPMyAdminを使用して、PHPプロジェクトでデータベースを作成できます。特定の手順は次のとおりです。PHPMyAdminにログインし、[新しい]ボタンをクリックします。作成するデータベースの名前を入力し、MySQLネーミングルールに準拠していることに注意してください。 UTF-8などの文字セットを設定して、文字化けの問題を回避します。

Redisメモリの断片化に対処する方法は? Redisメモリの断片化に対処する方法は? Apr 10, 2025 pm 02:24 PM

Redisメモリの断片化とは、再割り当てできない割り当てられたメモリ内に小さな自由領域の存在を指します。対処戦略には、Redisの再起動:メモリを完全にクリアしますが、サービスを割り当てます。データ構造の最適化:Redisに適した構造を使用して、メモリの割り当てとリリースの数を減らします。構成パラメーターの調整:ポリシーを使用して、最近使用されていないキー価値ペアを排除します。永続性メカニズムを使用します:データを定期的にバックアップし、Redisを再起動してフラグメントをクリーンアップします。メモリの使用量を監視する:問題をタイムリーに発見し、対策を講じる。

See all articles