[解決済み] React - 入力型ファイル セマンティックUI React
2022-02-07 18:27:50
質問
ファイルアップロードを実装しようとしていますが
サイア
<Input>
、ボタン、ラベルなど。
これは厳密には、レンダーでの要素の使用についてです。
通常のhtmlを使用する
<label>
と
<input>
この処理は期待通りに動作します。
<Form.Field>
<label>File input & upload for dataschemas & datasources</label>
<input type="file" onChange={this.fileChange} />
<Button type="submit">Upload</Button>
</Form.Field>
今度はSUIRを使ってみる
<Input>
要素に加え、いくつかのプロップは
<Button>
要素でスタイリングします。
<Form.Field>
<label>File input & upload </label>
<Input type="file" onChange={this.fileChange}>
<Button
content="Choose File"
labelPosition="left"
icon="file"
/>
</Input>
<Button type="submit">Upload</Button>
</Form.Field>
codesandboxにアクセスすることができます。 こちら をご覧いただくと、より視覚的にわかりやすいと思います。
をクリックすると
Choose File
SUIR の実装例では、ユーザーが自分のシステムからファイルを選択するように促されませんが、通常の html
<input>
があります。どうすれば
<Input type="file ...>
を意味的に同じように動作させることができます。
どのように解決するのですか?
SUIRは、FileInputボタンの解決策をそのまま提供するわけではありません。しかし、そのようなボタンの独自の実装を簡単に作成することができます。例えば、通常、これは
hidden
ファイル入力と、ユーザーがそれをクリックしたときに隠された入力のクリックをトリガーするボタンがあります。
<Button
content="Choose File"
labelPosition="left"
icon="file"
onClick={() => this.fileInputRef.current.click()}
/>
<input
ref={this.fileInputRef}
type="file"
hidden
onChange={this.fileChange}
/>
ここで
this.fileInputRef
が作成したReactのrefです。
React.createRef()
メソッドを使用します。
これを確認するには
コードとボックスの例
を、上記の解決策と一緒に使うことができます。
関連
-
[解決済み] あるJavaScriptファイルを他のJavaScriptファイルにインクルードするにはどうすればよいですか?
-
[解決済み] jQueryで入力を無効化/有効化する?
-
[解決済み] Reactルータを使ったプログラムによるナビゲーション
-
[解決済み] ngModel' は 'input' の既知のプロパティではないため、バインドできません。
-
[解決済み] React JSX内のループ
-
[解決済み] Reactのこの3つの点は何をするところなのでしょうか?
-
[解決済み] React NativeとReactの違いは何ですか?
-
[解決済み] React jsのonClickはメソッドに値を渡すことができない
-
[解決済み] ReactJSでコンポーネントがtext型の非制御入力を制御エラーに変更する場合
-
[解決済み】オブジェクトの型の名前を取得する
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】NodeJS "ESモジュールをロードするためにインポートを使用する必要があります。"
-
[解決済み】「Uncaught TypeError: Chromeで "Illegal invocation "が発生する。
-
[解決済み] テスト
-
[解決済み】React.jsの配列の子要素のユニークキーを理解する
-
[解決済み】JavaScriptで相対URLへのリダイレクトを行う
-
[解決済み】Kendo Observable Bindingと併用する場合、Kendo Switch Labelsを変更することは可能ですか?[Kendo-UI]です。
-
[解決済み】TypeError:res.jsonは関数ではありません。
-
[解決済み】'useState' が定義されていない no-undef React
-
[解決済み】Uncaught TypeError: 未定義のプロパティ 'msie' を読み取れない - jQuery tools
-
[解決済み] Uncaught (in promise) TypeError: フェッチに失敗してCorsエラー