new FileReader()

一、調(diào)用FileReader對象的方法

方法名 參數(shù) 描述
abort none 中斷讀取
readAsBinaryString file 將文件讀取為二進制碼
readAsDataURL file 將文件讀取為 DataURL
readAsText file, [encoding] 將文件讀取為文本

readAsText:該方法有兩個參數(shù),其中第二個參數(shù)是文本的編碼方式,默認(rèn)值為 UTF-8。這個方法非常容易理解,將文件以文本方式讀取,讀取的結(jié)果即是這個文本文件中的內(nèi)容。
readAsBinaryString:該方法將文件讀取為二進制字符串,通常我們將它傳送到后端,后端可以通過這段字符串存儲文件。
readAsDataURL:這是例子程序中用到的方法,該方法將文件讀取為一段以 data: 開頭的字符串,這段字符串的實質(zhì)就是 Data URL,Data URL是一種將小文件直接嵌入文檔的方案。這里的小文件通常是指圖像與 html 等格式的文件。

二、處理事件
事件 描述
onabort 中斷時觸發(fā)
onerror 出錯時觸發(fā)
onload 文件讀取成功完成時觸發(fā)
onloadend 讀取完成觸發(fā),無論成功或失敗
onloadstart 讀取開始時觸發(fā)
onprogress 讀取中

三、前端圖片數(shù)據(jù)加載顯示

<progress id="Progress" value="0" max="100"></progress>
<input type="file" name="file" onchange="showPreview(this)" />
<img id="portrait" src="" width="70" height="75">

function showPreview(source) {
        var file = source.files[0];
        console.log(file);
        if(window.FileReader) {
            var fr = new FileReader();
            fr.onloadend = function(e) {
//                console.log(this.result);
                document.getElementById("portrait").src = e.target.result;
            };
            //給FileReader對象一個讀取完成的方法,使用readAsDataURL會返回一個url,這個值就保存在事件對象的result里,img通過加載這個地址,完成圖片的加載
            fr.readAsDataURL(file);
        }
        var total = source.files[0].size;
        fr.onprogress = function(ev) {
            // 簡單測試了一下 大概12M左右的傳輸速度
            // 推薦測試的時候用一個視頻
            console.log(ev.loaded / total);
            var loading = (ev.loaded / total)*100;
            document.getElementById("Progress").value = loading;
        }
    }

四、base64與后臺交互
前端代碼


<input type="file" id="upload-file">
<script src="https://code.jquery.com/jquery-3.0.0.min.js"></script>
<script>
    // 用戶選擇圖片進行上傳
    // 上傳成功, 后臺返回圖片的URL
    // 顯示在當(dāng)前頁面上
    document.getElementById("upload-file").addEventListener("change", function(){
        for (var i = 0; i < this.files.length; i++) {
            var file = this.files[i];
            var reader = new FileReader();
            reader.onload = function (ev) {
                console.log(ev);
                console.log(ev.target.result);
                var base64Str = ev.target.result.split(",")[1];
                //console.log(base64Str)
                $.ajax({
                    url: "reImg.php",
                    data: {
                        "base64file": base64Str
                    },
                    type: "post",
                    success: function (res) {
                        createImg(res);
                    }
                })
            }
            reader.readAsDataURL(file);
        }
    });

    function createImg(imgSrc){
        var theImg = document.createElement("img");
        theImg.src = imgSrc;
        document.body.appendChild(theImg);
        theImg.className = "imgC";
    }

后端代碼


<?php
    // 接收前端傳遞過來的base64編碼
    $base64Str = $_POST["base64file"];

    // 利用方法解碼
    $img = base64_decode($base64Str);

    // 然后把圖片添加到img文件夾下, 圖片名, 由當(dāng)前毫秒數(shù)進行md5加密后的字符作為圖片名
    $name = md5(microtime());
    $result = file_put_contents("img/".$name.".jpg", $img);
//    umask(0777);
    //正常存入的圖片是沒有可寫權(quán)限的,加入具備最高權(quán)限
    chmod("img/".$name.".jpg",0777);
    // 然后判斷如果添加成功, 把這張圖片的URL返回給前端
    if ($result){
        $s = "http://localhost/BASE64/0301php/day6/uploadMore/";
        echo $s."img/".$name.".jpg";
    } else {
        echo "error";
    }
    
?>

(完)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,502評論 19 139
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,623評論 18 399
  • 項目中坑的出現(xiàn)往往是和需求的變動有關(guān)的 在日常工作中,我們不可避免的會接手維護老項目,或者將自己的項目交給其他人維...
    stormbaron閱讀 427評論 0 1
  • 不要在那兒傻坐著浪費時間了好嗎,以前一直在跟他們打交道,所以自己那個時候還比較有上進心,現(xiàn)在我發(fā)現(xiàn)真的,自己對學(xué)習(xí)...
    好想讀懂全世界閱讀 345評論 0 0
  • 運城汽車抵押貸款、運城不押車貸款151-9011-1506解經(jīng)理,全款車十折放款,外地車都不押車押手續(xù)超簡單不打?qū)?..
    汽車資訊閱讀 1,083評論 0 1

友情鏈接更多精彩內(nèi)容