SYNCERのロゴ
アイキャッチ画像

FileReader.result - 読み込んだデータ

resultは、FileReaderのプロパティです。読み込んだデータを返します。データの型は、読み込む時にどのメソッドを実行したかで変わります。

概要

名前
result
所属
FileReader
IDL
readonly attribute (DOMString or ArrayBuffer)? result;
仕様書
https://w3c.github.io/FileAPI/#dfn-result

説明

readAsDataURL()などの読み込み方法によって返り値の型が変わります。読み込みが完了した後じゃないと、空の文字列を返します。

チュートリアル

値を取得する例です。

<input type="file" multiple id="hoge">
// 要素を取得
var element = document.getElementById( "hoge" ) ;

// 読み込むファイル
var file = element.files[0] ;		// 1つ目のファイル

// FileReaderを作成
var fileReader = new FileReader() ;

// 読み込み完了時のイベント
fileReader.onload = function () {
	var value = fileReader.result ;	// ファイルの内容
}

// 読み込みを実行
fileReader.readAsText( file ) ;

デモ

選択したファイルの中から1つ目、つまりインデックス番号0([0])のファイルを取得します。ファイルを選択してみて下さい。選択したファイルが当サーバーに送信されることはありません。

<!-- このコードは編集できます。 -->

<!DOCTYPE html>
<html>
<head>
<style>
	div#result { white-space: pre-wrap ; }
	input { width: 95% ; font-size: 16px ; }
</style>
</head>
<body>
	<input type="file" multiple id="hoge">
<hr>
	<div id="result"></div>
<script>
var element = document.getElementById( "hoge" ) ;
var resultElement = document.getElementById( "result" ) ;

element.onchange = function () {
	var fileReader = new FileReader() ;

	fileReader.onload = function () {
		var value = fileReader.result ;
		console.log( value ) ;
		resultElement.appendChild( new Text( value ) ) ;
	}

	var file = element.files[0] ;
	fileReader.readAsText( file ) ;
}
</script>
</body>
</html>

サポート状況

ChromeFirefoxSafariEdgeIEOperaiOS SafariAndroid
6.0+ 10+ 30+ 6.0+ 4.0+
  • Twitterでシェア
  • Facebookでシェア
  • Google+でシェア
  • はてなブックマークでシェア
  • pocketに保存
  • LINEでシェア
更新履歴
2017年10月4日 (水)
コンテンツを公開しました。