HTML5之文件拖拽上傳

標(biāo)簽: 前端卦停、交互


今天某產(chǎn)品經(jīng)理蹭蹭蹭跑過來說向胡,我們現(xiàn)在項(xiàng)目里對(duì)圖片、文件上傳的交互體驗(yàn)不太好惊完,可不可以實(shí)現(xiàn)拖拽上傳僵芹。
然而拖拽要用到HTML5的Dragdrop屬性,并不兼容非現(xiàn)代瀏覽器小槐。


各位前端的同學(xué)們都曾為了IE8兼容舍棄了很多交互上的體驗(yàn)淮捆,但是何不做個(gè)區(qū)分,讓使用現(xiàn)代瀏覽器的用戶感受到我們炫酷的產(chǎn)品體驗(yàn)?zāi)亍?/p>

接下來是實(shí)踐本股!


首先使用Web Worker判斷是否為支持HTML5的瀏覽器

if (typeof(Worker) !== "undefined") {
    // 瀏覽器支持HTML5
} else {
    // 瀏覽器不支持HTML5
}

頁面中放置一個(gè)拖拽區(qū)域area,preview用于預(yù)覽圖片信息桐腌。(目前只寫了個(gè)圖片上傳)

<div id="area">將圖片拖拽到此區(qū)域</div> 
<div id="preview"></div> 

阻止瀏覽器默認(rèn)的拖拽操作:

$(document).on({
    dragleave:function(e){      //拖離
        e.preventDefault();
    },
    drop:function(e){           //拖后放
        e.preventDefault();
    },
    dragenter:function(e){      //拖進(jìn)
        e.preventDefault();
    },
    dragover:function(e){       //拖來拖去
        e.preventDefault();
    }
    });

上傳實(shí)現(xiàn)主體代碼拄显,主要用到文件API中的一個(gè)FileList接口,通過e.dataTransfer.files拖拽事件傳遞的文件信息案站,獲取本地文件列表信息躬审,通過length屬性獲取文件數(shù)量。如下:

var box = document.getElementById('area'); //拖拽區(qū)域
box.addEventListener("drop",
function(e) {
    e.preventDefault(); //取消默認(rèn)瀏覽器拖拽效果
    var fileList = e.dataTransfer.files; //獲取文件對(duì)象
    //檢測(cè)是否是拖拽文件到頁面的操作
    if (fileList.length == 0) {
        return false;
    }
    //檢測(cè)文件是不是圖片
    if (fileList[0].type.indexOf('image') === -1) {
        alert("您拖的不是圖片蟆盐!");
        return false;
    }
    //拖拉圖片到瀏覽器承边,可以實(shí)現(xiàn)預(yù)覽功能
    var img = window.webkitURL.createObjectURL(fileList[0]);
    var filename = fileList[0].name; //圖片名稱
    var filesize = Math.floor((fileList[0].size) / 1024);
    if (filesize > 500) {
        alert("上傳大小不能超過500K.");
        return false;
    }
    //alert(filesize);
    var str = "![](" + img + ")<p>圖片名稱:" + filename + "</p><p>大小:" + filesize + "KB</p>";
    $("#preview").html(str);

    //上傳
    xhr = new XMLHttpRequest();
    xhr.open("post", "upload.php", true);
    xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest");

    var fd = new FormData();
    fd.append('mypic', fileList[0]);

    xhr.send(fd);

},
false);

后端PHP接收上傳的文件信息(用于測(cè)試)石挂,代碼如下:

<?php
$mypic = $_FILES["mypic"];
if(!empty($mypic)){
    $picname = $_FILES['mypic']['name'];
    $picsize = $_FILES['mypic']['size'];
    if ($picsize > 512000) {
        echo '圖片大小不能超過500k';
        exit;
    }
    $type = strstr($picname, '.');
    if ($type != ".gif" && $type != ".jpg") {
        echo '圖片格式不對(duì)博助!';
        exit;
    }
    $pics = 'hello' . $type;
    //上傳路徑
    $pic_path = "pics/". $pics;
    move_uploaded_file($mypic["tmp_name"],$pic_path);
}
?>
<meta charset="utf-8">
<form action="" method="post" enctype="multipart/form-data">
<input type="file" name="mypic">
<input type="submit" value="上傳">
</form>

具體文件上傳方式待定,本文用于前端方法的實(shí)現(xiàn)說明痹愚,有利于現(xiàn)代瀏覽器用戶的交互體驗(yàn)富岳。


作者 @鄭小明

2016 年 08 月 17 日

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末蛔糯,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子窖式,更是在濱河造成了極大的恐慌蚁飒,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,273評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件萝喘,死亡現(xiàn)場(chǎng)離奇詭異淮逻,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)阁簸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門爬早,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人强窖,你說我怎么就攤上這事凸椿。” “怎么了翅溺?”我有些...
    開封第一講書人閱讀 167,709評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵脑漫,是天一觀的道長。 經(jīng)常有香客問我咙崎,道長优幸,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,520評(píng)論 1 296
  • 正文 為了忘掉前任褪猛,我火速辦了婚禮网杆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘伊滋。我一直安慰自己碳却,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評(píng)論 6 397
  • 文/花漫 我一把揭開白布笑旺。 她就那樣靜靜地躺著昼浦,像睡著了一般。 火紅的嫁衣襯著肌膚如雪筒主。 梳的紋絲不亂的頭發(fā)上关噪,一...
    開封第一講書人閱讀 52,158評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音乌妙,去河邊找鬼使兔。 笑死,一個(gè)胖子當(dāng)著我的面吹牛藤韵,可吹牛的內(nèi)容都是我干的虐沥。 我是一名探鬼主播,決...
    沈念sama閱讀 40,755評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼泽艘,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼置蜀!你這毒婦竟也來了奈搜?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,660評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤盯荤,失蹤者是張志新(化名)和其女友劉穎馋吗,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體秋秤,經(jīng)...
    沈念sama閱讀 46,203評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡宏粤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了灼卢。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片绍哎。...
    茶點(diǎn)故事閱讀 40,427評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖鞋真,靈堂內(nèi)的尸體忽然破棺而出崇堰,到底是詐尸還是另有隱情,我是刑警寧澤涩咖,帶...
    沈念sama閱讀 36,122評(píng)論 5 349
  • 正文 年R本政府宣布海诲,位于F島的核電站,受9級(jí)特大地震影響檩互,放射性物質(zhì)發(fā)生泄漏特幔。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評(píng)論 3 333
  • 文/蒙蒙 一闸昨、第九天 我趴在偏房一處隱蔽的房頂上張望蚯斯。 院中可真熱鬧,春花似錦饵较、人聲如沸拍嵌。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽横辆。三九已至,卻和暖如春打洼,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背逆粹。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評(píng)論 1 272
  • 我被黑心中介騙來泰國打工募疮, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人僻弹。 一個(gè)月前我還...
    沈念sama閱讀 48,808評(píng)論 3 376
  • 正文 我出身青樓阿浓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蹋绽。 傳聞我的和親對(duì)象是個(gè)殘疾皇子芭毙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容