亚洲免费乱码视频,日韩 欧美 国产 动漫 一区,97在线观看免费视频播国产,中文字幕亚洲图片

      1. <legend id="ppnor"></legend>

      2. 
        
        <sup id="ppnor"><input id="ppnor"></input></sup>
        <s id="ppnor"></s>

        js上傳文件預(yù)覽的簡單實例

        字號:


            下面小編就為大家?guī)硪黄猨s 上傳文件預(yù)覽的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。
            1. FILE API
            html5提供了FIle和FileReader兩個方法,可以讀取文件信息并讀取文件。
            2. example
            <html>
            <body>
            <div id="test-image-preview"
            style="border: 1px solid rgb(204, 204, 204); width: 100%; height: 200px; background-size: contain; background-repeat: no-repeat; background-position: center center;"> </div>
            <br/>
            <div id="test-file-info"></div>
            <br/>
            <input type="file" id="test-image-file">
            <script type="text/javascript">
            var
              fileInput = document.getElementById('test-image-file'),
              info = document.getElementById('test-file-info'),
              preview = document.getElementById('test-image-preview');
            // 監(jiān)聽change事件:
            fileInput.addEventListener('change', function () {
              // 清除背景圖片:
              preview.style.backgroundImage = '';
              // 檢查文件是否選擇:
              if (!fileInput.value) {
                info.innerHTML = '沒有選擇文件';
                return;
              }
              // 獲取File引用:
              var file = fileInput.files[0];
              // 獲取File信息:
              info.innerHTML = '文件: ' + file.name + '<br>' +
                       '大小: ' + file.size + '<br>' +
                       '修改: ' + file.lastModifiedDate;
              if (file.type !== 'image/jpeg' && file.type !== 'image/png' && file.type !== 'image/gif') {
                alert('不是有效的圖片文件!');
                return;
              }
              // 讀取文件:
              var reader = new FileReader();
              reader.onload = function(e) {
                var
                  data = e.target.result; // 'data:image/jpeg;base64,/9j/4AAQSk...(base64編碼)...'      
                preview.style.backgroundImage = 'url(' + data + ')';
              };
              // 以DataURL的形式讀取文件:
              reader.readAsDataURL(file);
            });
            </script>
            </body>
            </html>
            以DataURL的形式讀取到的文件是一個字符串,類似于data:image/jpeg;base64,/9j/4AAQSk...(base64編碼)...,
            常用于設(shè)置圖像。如果需要服務(wù)器端處理,把字符串base64,后面的字符發(fā)送給服務(wù)器并用Base64解碼就可以得到原始文件的二進(jìn)制內(nèi)容。
            3. 解釋
            上面的代碼還演示了JavaScript的一個重要的特性就是單線程執(zhí)行模式。在JavaScript中,瀏覽器的JavaScript執(zhí)行引擎在執(zhí)行JavaScript代碼時,總是以單線程模式執(zhí)行,也就是說,任何時候,JavaScript代碼都不可能同時有多于1個線程在執(zhí)行。
            你可能會問,單線程模式執(zhí)行的JavaScript,如何處理多任務(wù)?
            在JavaScript中,執(zhí)行多任務(wù)實際上都是異步調(diào)用,比如上面的代碼:
            reader.readAsDataURL(file);
            就會發(fā)起一個異步操作來讀取文件內(nèi)容。因為是異步操作,所以我們在JavaScript代碼中就不知道什么時候操作結(jié)束,因此需要先設(shè)置一個回調(diào)函數(shù):
            reader.onload = function(e) {
              // 當(dāng)文件讀取完成后,自動調(diào)用此函數(shù):
            };
            當(dāng)文件讀取完成后,JavaScript引擎將自動調(diào)用我們設(shè)置的回調(diào)函數(shù)。執(zhí)行回調(diào)函數(shù)時,文件已經(jīng)讀取完畢,所以我們可以在回調(diào)函數(shù)內(nèi)部安全地獲得文件內(nèi)容。
            以上這篇js 上傳文件預(yù)覽的簡單實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考