HTML5 fileReader用法

相關(guān)API

1.文件拖拽事件

  • ondragover -> 只要懸浮,一直觸發(fā)
  • ondragenter -> 進(jìn)入時(shí)觸發(fā),有子節(jié)點(diǎn)時(shí)有問題
  • ondragleave -> 離開時(shí)觸發(fā),有子節(jié)點(diǎn)時(shí)有問題
  • ondrop -> 釋放鼠標(biāo)時(shí)觸發(fā),對應(yīng)DOM節(jié)點(diǎn)的dragover事件必須取消默認(rèn)事件

2.File接口

  • var reader = new FileReader(); 新建文件讀取對象
    調(diào)用對象方法
  • .readAsText(file) -> 讀取文本文件
  • .readAsDataURL(file) -> 將文件讀取為 DataURL(二進(jìn)制流形式)
  • .readAsBinaryString -> 將文件讀取為 二進(jìn)制編碼

3.處理事件

  • .onload -> 資源讀取完畢 reader.result
  • .onprogress -> 讀取進(jìn)度更新時(shí)觸發(fā)
  • .onloadstart -> 加載開始時(shí)觸發(fā)
  • .onloadend -> 加載結(jié)束時(shí)觸發(fā)
  • .onerror -> 出現(xiàn)錯(cuò)誤時(shí)觸發(fā)
  • .onabort -> 加載過程中中止時(shí)觸發(fā)
  • .abort -> 手動(dòng)中止加載

代碼實(shí)現(xiàn)

HTML部分

    <input type="file" id="input_file"/>
    <div id="result" style="width: 100px;height: 100px;border: 1px solid #E1E1E1;"></div>
    <div id="box" style="width: 400px;height: 100px;border: 1px solid #E1E1E1;"></div>

Javascript

    var input=document.getElementById("input_file");
        var result=document.getElementById("result");
        if (window.FileReader) {
            input.addEventListener("change",imageUpload,false);
        } else{
            alert("瀏覽器不支持fileReader")
        }
      //普通上傳圖片
        function imageUpload () {
            var file = this.files[0];
            var reader = new FileReader();
            if(!/image\/\w+/.test(file.type)){
                alert("請確保文件為圖像類型");
                return false;
            }
            reader.readAsDataURL(file);
            reader.onload = function(ev) {
                console.log(this.result);//二進(jìn)制流
                result.innerHTML='![]('+this.result+')'
            }
        }

        //拖拽上傳圖片或處理文本或者多媒體(圖片  音頻 視頻)
        var oBox=document.getElementById("box");
            oBox.ondrop=function  () {
                var file = this.files[0];
                var reader = new FileReader();
                if (/txt/.test(file.type)) {
                    reader.readAsText(file);
                    reader.onload = function(ev) {
                    console.log(this.result);
                       document.write(this.result) 
                    }
                } else{
                    reader.readAsDataURL(file);
                    if (/iamge/.test(file.type)) {
                        reader.onload = function(ev) {
                           console.log("image");
                           var oImg=new Image();
                           oImg.src=this.result;
                           document.body.appendChild(oImg);
                        }
                    }
                    if (/video/.test(file.type)) {
                        reader.onload = function(ev) {
                           console.log("video");
                           new Video(this.result).play();
                        }
                    }
                    if (/audio/.test(file.type)) {
                        reader.onload = function(ev) {
                           console.log("audio")
                           new Audio(this.result).play();
                        }
                    }
                }
            }

以上為HTML5 fileReader用法,內(nèi)容不多理解較為容易,不再贅述。

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

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

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,727評(píng)論 18 399
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,569評(píng)論 19 139
  • H5 meta詳解 viewport width:控制 viewport 的大小,可以指定的一個(gè)值,如果 600,...
    FConfidence閱讀 891評(píng)論 0 3
  • 還是不跟你走了吧 人生的忐忑已經(jīng)夠多了 你的情書和車馬太慢了 不眠就算了 我想睡個(gè)好覺 四月的清晨還是有點(diǎn)冷 雪糕...
    夏詩琪閱讀 457評(píng)論 0 0
  • 妞妞: 前天我們?nèi)ソo弟弟拍照,看著你們倆拍照間隙在地毯上愉快的玩耍,我在朋友圈里發(fā)了一條——這一年,你14歲,他3...
    若水女子2017閱讀 875評(píng)論 9 8

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