勉強したことのメモ

webプログラマが勉強したことのメモ。

FileReader APIを用いて画像をアップロードせずにサムネイル表示

   

以前にFile APIを用いてファイル名やサイズ、形式(拡張子)を取得するメモを書いたが、この応用で画像をアップロードせずにサムネイル表示できるんじゃないかと思った。調べてみたところFileReader APIを用いることで対応できた。以下に実装方法をメモ。

 

FileReader APIのリファレンス

https://developer.mozilla.org/ja/docs/Web/API/FileReader

 

サンプル

https://taitan916.info/sample/fileapi/index2.php

上記ページで画像を選択するとサムネイルが表示される。

 

ソースコード

<html lang="ja">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>File APIでサムネイル表示</title>
</head>
<style>
.thumb img{
	max-width: 150px;
	margin-bottom: 10px;
}
</style>
<body>

<input type="file" name="img_1" id="img_1" class="img">
<div id="thumb_1" class="thumb"></div>

<input type="file" name="img_2" id="img_2" class="img">
<div id="thumb_2" class="thumb"></div>

<script type="text/javascript" src="//code.jquery.com/jquery-3.5.1.js"></script>
<script type="text/javascript">
$(function(){
	$('.img').change(function(){

		//ID取得
		let tmp_id = $(this).attr('id');
		tmp_id = tmp_id.split('_');
		const id = tmp_id[1];

		//画像取得
		const img = $('#img_' + id).prop('files')[0];
		const type = img.type;

		//画像かどうかチェック
		if( !type.match(/^image/) ){
			alert('画像を選択してください');
			$(this).val('');
			return false;
		}

		//FileReaderオブジェクトのインスタンス化
		let reader = new FileReader();

		//画像の読み込み
		reader.readAsDataURL(img);

		//読み込み失敗時
		reader.onerror = function(){
			alert('ファイル読み取りに失敗しました');
			$(this).val('');
			return false;
		}

		//画像を表示
		reader.onload = function() {
			$('#thumb_' + id).html('<img src="' + reader.result + '">')
		}

	});
})
</script>
</body>
</html>

 

対応ブラウザ

以下リファレンスを確認したところ、おおよそのPC / SPブラウザに対応している模様。

https://developer.mozilla.org/ja/docs/Web/API/FileReader#browser_compatibility

 

所感

画像をアップロードすることなくサムネイル表示できるのは非常に便利かもしれない。さらにおおよそのブラウザにも対応しているようなので実用性がありそう。

 

参考サイト

http://tech.innovation.co.jp/2017/02/25/image-File-Reader.html

https://cly7796.net/blog/javascript/use-the-file-api-to-display-a-thumbnail-of-the-image-that-is-referenced-from-the-local/

 - JavaScript, HTML

  関連記事

Chart.jsでグラフの描写

JavaScriptでグラフを描写する必要があり、普段はHighchartを使用 ...

ajaxを使わずに非同期っぽくsubmitする

ajaxを使わずに見た目はページ遷移せず、 画像を含めたformをsubmitし ...

さくらレンタルサーバでCookieが保存できない

さくらインターネットのレンタルサーバでjquery.cookie.jsを用いてC ...

クロスドメインのiframeで子フレームから親フレームにheightの値を渡す

やりたかった事は、 ・iframeで子フレームから親フレームにheightの値を ...

navタグ

デザイナーさんより受け取ったファイルにて navという見慣れないタグがあったので ...

formでdisplay:none;にしてても送信される

formで特定の部分をdisplay:none;で非表示にしてても 内容は送信さ ...

画像の一部分のみリンクを設定する方法

画像を表示させて、その画像の一部分のみにリンクを張りたかった。画像を重ね合わせた ...

leaflet.jsとOSMでマーカーの画像をそれぞれ指定する

leaflet.jsとOpenStreetMapでマップ上にマーカーを複数設置し ...

マウスオーバーでの画像切り替えをJavaScriptで簡単に対応

マウスが要素にのった際に画像を切り替える処理を入れたかった。多分CSSの管轄なん ...

jquery.cookie.jsで保存期間を時間指定する方法

jquery.cookie.jsで保存期間を1時間等、時間指定したい。公式サイト ...