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

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

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

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Bootstrap

BootstrapはウェブサイトデザインやUIのWebアプリケーションを素早く 作成する可能なCSSフレームワークです。 Twitter風のデザインを作成することができます。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

2回答

823閲覧

htmlで画像ファイルを複数同時に選択しアップロードする際に、プレビュー表示が出来る、画像1枚ずつに対して削除が出来るようなライブラリを探しています。

nyamuoo

総合スコア2

JavaScript

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Bootstrap

BootstrapはウェブサイトデザインやUIのWebアプリケーションを素早く 作成する可能なCSSフレームワークです。 Twitter風のデザインを作成することができます。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

2クリップ

投稿2021/12/20 09:53

タイトルに記載した機能が含まれているライブラリを探しています。
画像ファイルを複数アップロードする必要があり、アップロード前にプレビューで確認をしつつ、不必要なファイルを削除する機能が欲しいです。
お手数おかけしますがご存知の方がいらっしゃいましたら教えて頂けると助かります。
よろしくおねがいします。

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

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

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

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

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

guest

回答2

0

こんな感じで

javascript

1<?PHP 2print_r($_FILES);//自分自身に送ってファイルを確認する 3?> 4<style> 5.droppable{ 6border:1px solid; 7position:relative; 8height:300px; 9} 10.droparea{ 11position:absolute; 12top:0; 13width:100%; 14height:100%;; 15opacity:0; 16background-Color:lime; 17} 18#preview img{ 19 max-width:100px; 20 max-height:100px; 21} 22</style> 23<script> 24window.addEventListener('DOMContentLoaded', ()=>{ 25 const list=[]; 26 document.querySelector('.droparea').addEventListener('change',e=>{ 27 list.length=0; 28 var target=e.target; 29 document.querySelector('#preview').textContent=""; 30 [...target.files].forEach((file,idx)=>{ 31 if(file !==undefined){ 32 var fr = new FileReader(); 33 fr.addEventListener('load',e=>{ 34 var type=file.type; 35 var name=file.name; 36 if(["image/jpeg","image/gif","image/png"].includes(type)){ 37 var blob=new Blob([e.target.result],{type}); 38 var binary=String.fromCharCode.apply("",new Uint8Array(e.target.result)); 39 var base64="data:"+file.type+";base64,"+btoa(binary); 40 var img=Object.assign(document.createElement('img'),{src:base64}); 41 list.push({blob,name}); 42 img.addEventListener('click',()=>{ 43 list[idx]=false; 44 console.log(list); 45 img.remove(); 46 }); 47 document.querySelector('#preview').appendChild(img); 48 }else{ 49 target.value=""; 50 } 51 }); 52 fr.readAsArrayBuffer(file); 53 } 54 }); 55 }); 56 document.addEventListener('submit',(e)=>{ 57 document.querySelector('[type=file]').disabled=true; 58 }); 59 document.addEventListener('formdata',(e)=>{ 60 list.forEach(x=>{ 61 if(x) e.formData.append(document.querySelector('[type=file]').name,x.blob,x.name); 62 }); 63 }); 64}); 65</script> 66<form method="post" enctype="multipart/form-data"> 67<div class="droppable"> 68<div>ドロップして</div> 69<input type="file" class="droparea" name="myfile[]" multiple> 70</div> 71<input type="submit"> 72<div id="preview"></div> 73</form>

投稿2021/12/20 11:29

編集2021/12/20 13:00
yambejp

総合スコア114777

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

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

0

DropzoneJSはどうですか?

投稿2021/12/20 10:40

skys215

総合スコア910

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問