ホームページ ウェブフロントエンド jsチュートリアル タイプスクリプトタイプの推論について混乱しているものは何ですか。4つのタイプには同じ結果があり、条件付きタイプを組合型と一致させる問題はありますか?

タイプスクリプトタイプの推論について混乱しているものは何ですか。4つのタイプには同じ結果があり、条件付きタイプを組合型と一致させる問題はありますか?

Apr 04, 2025 pm 05:33 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つのタイプ定義はすべて、関数タイプからの返品値タイプを推測するように設計されています。パラメータータイプ(...args: never)(...args: never[])(...args: any[]) 、および(...args: any)は違うように見えますが、タイプの推論で一貫してパフォーマンスします。これは、 extendsキーワードが主にパラメーターの数と関数の値タイプに焦点を合わせ、パラメータータイプの詳細を厳密に確認しないためです。不可能なタイプを表すnever 、いずれany任意のタイプを表し、空の配列を表すことnever[] 。これらの違いは、戻り値タイプの推論プロセス中に無視されます。したがって、関数の戻り値タイプRを正しく推測できます。

次に、条件付きタイプが組合タイプと一致しないという問題を分析します。

タイプ小道具<t extends major rescategorylabel> = {
  ラベル:t [];
  setSelect:(index:number、label:t extends major?major:rescategorylabel)=> void;
  xxx;
};

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

setSelect関数の2番目のパラメーターlabelT extends Major ? Major : ResCategoryLabel 。問題は、 TMajor | ResCategoryLabelであることですMajor | ResCategoryLabel 、TypeScriptはlabelのタイプを決定できません。条件付きタイプは、 TMajorであるかどうかに基づいてタイプを選択しようとしますが、 T MajorまたはResCategoryLabelである可能性があり、タイプの推論が特定のタイプを与えないため、タイプのミスマッチエラーが発生します。これはコードロジックエラーではなく、組合タイプと条件付きタイプを扱う際の型タイプスクリプトタイプシステムの制限です。回避策では、タイプアサーションまたはより粒状タイプ定義を使用してlabelを明示的に入力するなど、 Propsタイプのタイプ定義をリファクタリングするか、機能を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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

See all articles