質問編集履歴

2

対応

2016/04/27 13:48

投稿

k499778
k499778

スコア599

test CHANGED
File without changes
test CHANGED
@@ -93,3 +93,65 @@
93
93
  [アップロード時に選択したファイルをクリア](http://php.o0o0.jp/article/jquery-file_clear)
94
94
 
95
95
  そのとき再度changeイベントを登録するのに、いちいちこの長ったらしいコードを書かずに済むように関数化しておきたいというところです。
96
+
97
+
98
+
99
+ ```javascript
100
+
101
+ $('.fileInput').change(function(){
102
+
103
+ displayImage(this);
104
+
105
+ }
106
+
107
+
108
+
109
+
110
+
111
+
112
+
113
+ function displayImage(_this) {
114
+
115
+ // 1. 選択されたファイルがない場合は何もせずにreturn
116
+
117
+ if (!_this.files.length) {
118
+
119
+ return;
120
+
121
+ }
122
+
123
+
124
+
125
+ var file = _this.files[0], // 2. files配列にファイルが入っています
126
+
127
+ $_img = $(_this).siblings('img'), // 3. jQueryのsiblingsメソッドで兄弟のimgを取得
128
+
129
+ fileReader = new FileReader(); // 4. ファイルを読み込むFileReaderオブジェクト
130
+
131
+
132
+
133
+ // 5. 読み込みが完了した際のイベントハンドラ。imgのsrcにデータをセット
134
+
135
+ fileReader.onload = function(event) {
136
+
137
+ // 読み込んだデータをimgに設定
138
+
139
+ $_img.attr('src', event.target.result);
140
+
141
+ };
142
+
143
+
144
+
145
+ // 6. 画像読み込み
146
+
147
+ fileReader.readAsDataURL(file);
148
+
149
+ }
150
+
151
+
152
+
153
+
154
+
155
+ // displayImage(this)を再登録したい
156
+
157
+ ```

1

修正対応

2016/04/27 13:48

投稿

k499778
k499778

スコア599

test CHANGED
File without changes
test CHANGED
@@ -61,3 +61,35 @@
61
61
 
62
62
 
63
63
  もしわかる方がいらっしゃったら教えていいただければと思います。
64
+
65
+
66
+
67
+
68
+
69
+ ---
70
+
71
+ 追記
72
+
73
+
74
+
75
+ 一例ですが、今回のパターンで言うと
76
+
77
+ [<input type="file">を使って画像を表示したい](https://teratail.com/questions/33141)のときです。
78
+
79
+
80
+
81
+
82
+
83
+ 以下サイトの ```$('.fileInput').change(function(){```の中を関数にしたいのです。
84
+
85
+ [FileAPIを使った画像表示](http://blog.asial.co.jp/1079)
86
+
87
+
88
+
89
+ というのも<input type="file">の値を消すのにIEの古いバージョンだと一度このコードを消してしまって
90
+
91
+ もう一度生成しなければいけないからです。
92
+
93
+ [アップロード時に選択したファイルをクリア](http://php.o0o0.jp/article/jquery-file_clear)
94
+
95
+ そのとき再度changeイベントを登録するのに、いちいちこの長ったらしいコードを書かずに済むように関数化しておきたいというところです。