PHP 板


LINE

看板 PHP  RSS
※ [本文轉錄自 Ajax 看板 #1PLcDdTn ] 作者: liisi (小心一點) 看板: Ajax 標題: [問題] 圖檔拖曳到頁面上預覽 遇到問題 時間: Fri Jun 30 22:42:44 2017 各位版友晚安 想請問一下 關於圖片拖拉到網頁上呈現的問題 之前都是透過點選按鈕 選擇檔案的方式 選擇圖片 畫面上會有預覽的圖片 之後再上傳 PS. 其實要上傳多張圖(是用迴圈跑的) 我用數字1表示第一張 有google到html5 但是目前對 html5 不熟悉 囧rz 簡單的範例: <div id="imgtest1"> <img id="img1" onclick="$('#pic1').click();"> </div> <input type="file" id="pic1" name="pic[]" onchange="return getPath(1);"/> ========================================================================== function getPath(obj) { if(typeof(FileReader) != 'undefined') { var reader = new FileReader(); var file = document.getElementById('pic'+obj); reader.onload = function(e) { document.getElementById("img"+obj).src = e.target.result; } reader.readAsDataURL(file.files.item(0)); } } ========================================================================== 這時候 我只要在php端 針對 $_FILES['pic']['tmp_name'] 做處理即可 但是現在要做拖曳的功能 我上網看了一下 就在<div>加上事件 ondragover="javascript:dragHandler(event);" ondrop="javascript:drop_image(event,1);" ========================================================================== function dragHandler(e) { e.stopPropagation(); e.preventDefault(); } function drop_image(e,obj) { e.stopPropagation(); e.preventDefault(); var files = e.dataTransfer.files; for(var i=0; i<files.length; i++) //其實有多張圖 { var pic_file = files[i]; var img_url = window.webkitURL.createObjectURL(pic_file); document.getElementById("img"+obj).src = img_url; } } ========================================================================== 這時候 網頁上 是看得到預覽圖 但是<input type="file">裡面 卻沒有東西 導致我在php端 無法針對 $_FILES['pic']['tmp_name'] 做處理 應該是 如果是用點選按鈕 在選擇檔案方式 會自己塞進去...... 我原本想把 pic_file塞到 <input type="file">裡面 但是卻不行 google了一下 也說不能直接將 <input type="file">塞值就去 想請教板友 要怎做才行 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 49.159.65.63
※ 文章網址: https://webptt.com/m.aspx?n=bbs/Ajax/M.1498833767.A.771.html



※ 發信站: 批踢踢實業坊(ptt.cc)
※ 轉錄者: liisi (49.159.65.63), 06/30/2017 23:09:12
1F:→ liisi: 抱歉 轉錄一下 也請版友幫忙解答疑惑 06/30 23:09
2F:→ gpmm: 你用的 js 套件在拖曳後要自動呼叫上傳… 07/01 18:21
3F:→ liisi: 不能先自動上傳 一定要按下儲存 才可以上傳... 07/01 22:22
4F:推 water2924: 你沒搞懂2樓的意思... 你原本是靠input的方式送file 07/02 17:26
5F:→ water2924: 現在你改用drop的方式後, 你要在弄個function幫你上傳 07/02 17:27
6F:→ liisi: 我知道2樓意思 所以不能靠input file方式囉? 07/02 22:25
7F:→ liisi: 因為想說如果可以直接在input file塞值 就無需太大變動 07/02 22:27
8F:推 water2924: security issue, input file只能透過視窗填值 07/03 00:04
9F:推 water2924: 你如果不用input file的dialog 你要自己用js送formData 07/03 00:10
10F:→ water2924: google一下 XMLHttpRequest 07/03 00:22
11F:→ gpmm: 沒有進行上傳這個動作,你的後端(PHP)要怎麼收到任何東西 07/04 00:51
12F:→ gpmm: 塞在 input file 本來就可以(也是最簡便的方式)重點是在 07/04 00:52
13F:→ gpmm: 塞進去之後你做了什麼啊?沒做任何事情那他就只是個 07/04 00:52
14F:→ gpmm: 帶值的 input file 而已啊,你 PHP 收的到誰了這是… XD 07/04 00:53
15F:→ liisi: 我google的時候 有看到上面版友提到的方式 07/04 10:50
16F:→ liisi: 只是這樣 要改動的程式 會比較多 看來只能這樣了Q_Q 07/04 10:50
17F:→ liisi: 感謝大家!! 07/04 10:51







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:BuyTogether站內搜尋

TOP