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

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

新規登録して質問してみよう
ただいま回答率
85.35%
Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

キャスト

キャストとは、オブジェクトの型の変換が許可された場合に、明白に別の型への変換を行うプロセスのことです。

TypeScript

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

React.js

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

Q&A

解決済

1回答

5860閲覧

TypeScriptの形推論やキャストについて

front

総合スコア12

Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

キャスト

キャストとは、オブジェクトの型の変換が許可された場合に、明白に別の型への変換を行うプロセスのことです。

TypeScript

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

React.js

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

0グッド

0クリップ

投稿2020/09/12 00:15

前提・実現したいこと

個人でプログラミング開発しており、firebaseで画像upload機能を追加しようと考えている。
そこでblobへの変換を試みたところ、型の整合性がなくエラーとなるケースが多々ある。

発生している問題・エラーメッセージ

型 'FileList | null' の引数を型 'BlobPart[] | undefined' のパラメーターに割り当てることはできません。 型 'null' を型 'BlobPart[] | undefined' に割り当てることはできません。ts

該当のソースコード

const imageUpload = (e: React.ChangeEvent<HTMLInputElement>) => { const file = e.target.files; console.log(file);   //blob作成としての記述は間違っていないが型の整合性で怒られる const blob = new Blob(file, { type: "image/jpeg" }); };

不明点

変数fileの型が FileList | nullnew blobの引数は(blobParts?: BlobPart[] | undefined, options?: BlobPropertyBag | undefined)となっており、第一引数にfileが当てはまらないのはわかるが、力技のキャストでは保守性がなくなるためできる限り使用したくない。

blob作成にあたっての記述方法は間違っていないが、どうしても型の整合性が取れない場合の対応を教えて欲しいです。
よろしくお願いいたします。

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

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

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

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

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

Zuishin

2020/09/12 00:18

力業のキャストが一番保守性が高そうな気がしますが。
front

2020/09/12 00:23

@Zuishin コメントいただきありがとうございます。 キャスト = 「本来の型ではない型を強引に入れている」 そのためバグの起因につながると考えているのですが、こちらの認識は間違いでしょうか。
maisumakun

2020/09/12 00:26

fileがnullとなった場合は、どのような処理をさせたいのですか?
front

2020/09/12 00:28

@maisumakun fileがnullの場合は、一旦alertなどでエラー表示をさせたいと考えております。
guest

回答1

0

ベストアンサー

fileがnullの場合は、一旦alertなどでエラー表示をさせたいと考えております。

では、その条件分岐をすれば解決するかと思います。

typescript

1 const file = e.target.files; 2 console.log(file); 3 if(file) { 4 // 条件分岐の関係上、この中ではfile==nullの可能性は消え、 5 // fileはFileList型に確定する 6 const blob = new Blob(file, { type: "image/jpeg" }); 7 } else { 8 alert('適当なメッセージ'); 9 } 10

投稿2020/09/12 00:39

maisumakun

総合スコア146018

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

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

front

2020/09/12 01:24

@maisumakun 回答いただきありがとうございます。 こちらでnullについては消えること確認できました。 しかし下記のエラーは残っている状態です。こちらは変数fileをキャストするしか方法はないのでしょうか。 型 'FileList' の引数を型 'BlobPart[]' のパラメーターに割り当てることはできません。
maisumakun

2020/09/12 01:34

冷静に考えれば、new Blob自体が不要でした。 e.target.files[0]のようにして回収できるFile自体がBlobを継承しているので、Fileをそのまま使えばいいだけかと思います。
maisumakun

2020/09/12 01:47

(FileListやfilesという名前の通り、e.target.filesはファイルを複数含みうるオブジェクトです。ファイル1つは、添字で参照する必要があります)
front

2020/09/12 02:03

@maisumakun ありがとうございます。 コメントいただき解決することができました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問