質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.37%
ユニットテスト

ユニットテストは、システムのテスト手法の一つで、個々のモジュールを対象としたテストの事を指します。対象のモジュールが要求や性能を満たしているか確認する為に実行します。

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

解決済

2回答

933閲覧

TypeScriptでRouteComponentProps<{ id: string}>をextendするInforPropsを渡すには?

Sean2014

総合スコア59

ユニットテスト

ユニットテストは、システムのテスト手法の一つで、個々のモジュールを対象としたテストの事を指します。対象のモジュールが要求や性能を満たしているか確認する為に実行します。

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

1クリップ

投稿2020/08/20 17:24

React TypeScriptで実験的に次のようにテストコードを書き始めたのですが、

[Login.test.tsx]

import React from 'react'; import { shallow } from 'enzyme'; import Login from './Login'; describe('Login', () => { const login = shallow(<Login />); });

Type '{}' is missing the following properties from type 'Readonly<ILoginInfoProps>'というエラーが出てきます。

調べていたらLoginコンポーネントのPropsにデフォルト値を設定する必要があり、そしてその型は次のようなILoginInfoProps型で定義されているからそれに合わせる必要があるという所までわかりました。

[ILoginInfoProps.interface.ts]

import { RouteComponentProps } from 'react-router-dom'; export default interface ILoginInfoProps extends RouteComponentProps<{}>{ id: string }

次のようにデフォルト値を設定しようとしたのですが、コンパイルしません。

[Login.tsx]

import React from 'react'; import LoginInfo from '../interfaces/LoginInfo.interface'; import ILoginInfoProps from '../interfaces/ILoginInfoProps.interface'; import ILoginInfoState from '../interfaces/ILoginInfoState.interface'; class Login extends React.Component<ILoginInfoProps, ILoginInfoState>{ public static defaultProps: ILoginInfoProps = { match: { id: '24'; } }; ....... .......

Type '{ id: string; }' is not assignable to type 'match<{}>'.
Object literal may only specify known properties, and 'id' does not exist in type 'match<{}>'.ts(2322)
index.d.ts(76, 5): The expected type comes from property 'match' which is declared here on type 'ILoginInfoProps'.というエラーが出てきてしまいます。

どのように直せばよいでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

エラーが起こっている原因は、ILoginInfoPropsを定義するときにフィールドの記述がいくつか欠けているからではないでしょうか。ここではhistory, match, locationがそれに該当すると思われます。interface ILoginInfoPropsはRouteComponentProps<{}>をextendしていますので。

下記のようにしてみてください。

public static defaultProps: ILoginInfoProps = { id: '24', history: undefined, location: undefined, match: undefined }

投稿2020/08/29 11:13

furitetepporaa

総合スコア20

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Sean2014

2020/08/29 11:40

ドンピシャでした!ありがとうございます!
guest

0

次のようにデフォルト値を設定しようとしたのですが、コンパイルしません。

matchというプロパティがILoginInfoPropsに存在しないからではないでしょうか?
下記のようにidだけをdefaultPropsに指定した場合は動作しませんか?

typescript

1public static defaultProps: ILoginInfoProps = { 2 id: '24'; 3};

以下参考です。

投稿2020/08/26 00:23

nekoniki

総合スコア2411

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Sean2014

2020/08/29 11:42

回答ありがとうございます。ただ、ご提案いただいたコードの内容ではコンパイルエラーは解消されませんでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.37%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問