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

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

新規登録して質問してみよう
ただいま回答率
85.46%
ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

MongoDB

MongoDBはオープンソースのドキュメント指向データベースの1つです。高性能で、多くのリトルエンディアンシステムを利用することができます。

アップロード

アップロードは特定のファイルをウェブサーバに送るプロセスのことを指します。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

React.js

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

Q&A

解決済

1回答

4277閲覧

React ファイルアップロードしたい

hiro_ike

総合スコア48

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

MongoDB

MongoDBはオープンソースのドキュメント指向データベースの1つです。高性能で、多くのリトルエンディアンシステムを利用することができます。

アップロード

アップロードは特定のファイルをウェブサーバに送るプロセスのことを指します。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

React.js

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

0グッド

0クリップ

投稿2021/08/29 08:26

プログラミング初心者です。
自分にとって使いやすいメモ帳アプリを作成しようとしています。
メモ書きにファイルもアップロードしたいです。

ファイルアップロードのスキーマの書き方が分からず、
この手の情報が見つけられなかったため、
スキーマの書き方アドバイスいただけたら助かります。

現状のmodelsファイル

JavaScript

1const { Schema, model } = require('mongoose'); 2const noteSchema = new Schema({ 3 title: { type: String, required: true, unique: true }, 4 noteBody: String, 5}, { 6 timestamps: true 7}) 8 9module.exports = model('Note', noteSchema ) 10

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2021/08/30 03:14

なんやろ。アップロードしたいファイルのアイコンをドラッグして、メモ帳アプリのどこかにドロップすると、アップロードされる的なやつ作りたいんか?
hiro_ike

2021/08/30 13:11

コメントありがとうございます。はい、そうです。 最終的に、slackの自分のメッセージ欄ありますね、ああいうものを作れたらと思いました。メモも残せ、ファイルも置いておけて便利だなと思ったのですが、その場合はファイルの格納場所はどういうサービスを使うのが一般的なのでしょうか? m(_ _ )m
guest

回答1

0

ベストアンサー

質問への追記・修正の依頼でのご返答をふまえて、フロントエンドで使えそうなライブラリを回答します。

まず、今回のように

何らかの汎用的な機能(今回だと、ファイルアイコンのドロップをうけつける。)が実装されてライブラリになっているコンポーネントを探す

というタスクは、仕事のときも趣味で何か作るときでも、ようありますわ。そういうときに、イイのがチャチャッと見つかるような検索ができるというのも、ひとつのスキルやで。

今回だったら、以下のようなワードで検索してみる。

  • React ファイル ドラッグ&ドロップ
  • React ファイル ドラッグ&ドロップ アップロード
  • React files Drag and Drop
  • React files Drag and Drop and Upload

それで該当して上位に出てきたライブラリの比較記事とか使ってみた的な記事をざっと流し読みする。そして、それらの記事でオススメされているNodeモジュールのGitHubのレポジトリを見て、スターが何個ついているか、とか、issueでの議論が活発に最近も行われているか、あたりを見ておく。そうするとだいたい候補が絞られてきますわ。

今回の場合は、答えを言ってしまうと、

がええやろ思いますわ。日本語の記事もすぐ見つかります。

それと、YouTubeでも、 react-dropzone で検索すると、色々出てきます。だいたい英語やけど、VSCodeの画面見せながら、ちょっとずつ実装していく系の動画やと英語苦手でもなんとなく内容追えるもんや。

react-dropzoneを使っても、何らかのトリガーでファイルのアップロードを行う部分は自分で書くことになりますが、そのときに上の記事のAWS S3に送るほうの例は参考になるかと思います。hiro_ikeさんの場合は、S3 ではなく自分で用意したバックエンドのファイルアップロードAPIの仕様に合わせて送るということで、ざっくりいうとそこが変わると思えばええかと。

余談ですが、ドロップエリアとアップロード機能をひとまとめにしたものを作ってくれた人もおる。

これも便利そうやけど、その分、使い方を把握するだけでも時間かかりそうやね。とりま以上ですう〜。

投稿2021/08/31 07:54

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

hiro_ike

2021/08/31 13:55

ご丁寧にありがとうございます。 これ以上ない説明でした。 自分では、ドラッグ&ドロップというのにさえ辿り着けなかったと思います。 ライブラリというのが使えるのですね、ご教授いただいたページ見てみます! ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問