文件上傳

来源:http://www.cnblogs.com/xfe2017/archive/2017/10/18/7685232.html
-Advertisement-
Play Games

工作中寫了一個文件上傳的vue組件。本來只有點擊input選擇的功能,但是drag流行了起來,產品也要求加入拖拽上傳的功能,於是就遇到瞭如上所述的問題, ...


拖拽選擇文件

屏蔽預設事件

剛開始的時候,是在網上找了一個例子,這個例子中提到,需要在document上屏蔽和drag相關的所有事件的預設處理方式,代碼如下:

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

實際上,在我們的文件上傳中,接受拖拽的區域一般只有一個小區域,所以我對其做瞭如下的精簡

$drop.on("dragenter", function (e) {
    e.preventDefault();
    console.log("enter");
    $drop.addClass("hover");
});
$drop.on("dragleave drop", function (e) {
    e.preventDefault();
    console.log("leave");
    $drop.removeClass("hover");
});
$drop.on("dragover", function (e) {
    e.preventDefault();
})                    

並且,在enter事件的時候,給目標區域增加了一個hover的樣式,讓接受區域高亮

預設情況下是醬紫的,(所以在drop 和leave事件中要去掉這個樣式

對來源不同的文件進行處理

因為要同時處理input框和拖拽區域,所以我的html結構如下:

             <div class="row" id="dropBox" @drop.prevent="Change($event)">
                <div class="import-data">
                    <button 
                        :class="{'disabled' : resultMsg.length > 0}"
                        class="btn btn-info">
                        <i class="fa fa-cloud-upload text"></i>
                        選擇文件
                    </button>
                    <span :class="{'error-tips':isError}">{{msg}}</span>
                    <input 
                        type="file" 
                        v-show="resultMsg.length == 0" 
                        @change="Change($event)" 
                        name="importExcel" 
                        class="importExcel" 
                        value="" />
                </div>
                <br>
                <div class="loading" :style="'width:'+loading+'%'"></div>
            </div>

#dropBox 的drop事件和input的change事件同時綁定Change函數並將event對象傳入函數中
這裡,我在drop事件上加入了prevent修飾符來屏蔽預設事件,如果不屏蔽事件,接受區域#dropBox 是無法接收到文件,並且文件會觸發瀏覽器的下載(如果不能直接預覽的話)或者預覽;

            Change:function(ev){
                var e = window.event || ev; 
                var file = e.target.files ? e.target.files[0] : e.dataTransfer.files[0];
                if(!file){
                    vm.msg = "點擊選擇,或者拖拽填寫好數據的excel文件致此";
                    vm.isError = true;
                    return false
                }               
            },

ps:隱去了js代碼中的業務邏輯只講述公共部分,

在接受用戶選擇的文件時,用e.target.files作為判斷條件,來判斷是否有input選擇的文件,如果是則取 e.target.files[0] ,如果不是 則取 e.dataTransfer.files[0]
這兩個事件對象的屬性是瀏覽器根據不同的情況掛在事件對象上的。

還有bug沒解決暫時收工 …………

未完待在續


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 概述 我們都知道面向對象有四個基本特性:抽象、封裝、繼承、多態。這四個特性,概括起來可以這麼理解,抽象、封裝、繼承是多態的基礎,多態是抽象、封裝、繼承的表現。多態,是Java中非常重要的一個部分,所以今天來談一下多態(Polymorphism)。 什麼是多態 不同類的對象對同一消息作出不同的響應就叫 ...
  • Python 生成器 ...
  • 說到記憶體管理,筆者這裡想先比較一下java與C、C++之間的區別: 在C、C++中,記憶體管理是由程式員負責的,也就是說程式員既要完成繁重的代碼編寫工作又要時常考慮到系統記憶體的維護 在java中,程式員無需考慮記憶體的控制和維護,而是交由JVM自動管理,這樣就不容易出現記憶體泄漏和溢出的問題。然而,一旦出 ...
  • random是內置模塊,使用時直接import random random.random() --> 生成一個0到1的隨機符點數: 0 <= n < 1.0 random.uniform(a,b) --> 生成一個a到b的隨機符點數: a <= n < b random.randint(a,b) - ...
  • 也許上一篇博文提到的property內置函數的用法你還覺得記憶猶新,那麼有沒有更多的類似的方法呢?有的,就是本篇文章要說的魔法方法 魔法方法 1.什麼是魔法方法 (其實前面已經提到多次,每次我都是說暫且不談,後面會提到,在這裡終於填坑了) 總是被雙下劃線包圍的方法,比如__init__ 魔法方法是面 ...
  • 2017-10-16 公司裡面其他人發現了一個問題,五糧液金品庫存出現了問題,刪除了庫存也沒還回來,一瓶一千多。而且在我的功能塊,在我看出貨詳情的時候,詭異的事情發生了,第一眼看上去沒問題呀,刷新了一下,天哪!頁面上的數字隨著我的刷新在變動,刷一下變一下,資料庫也是。想起前幾天,老大說這裡展示有點問 ...
  • 單例模式的要點有三個: 一是某個類只能有一個實例; 二是它必須自行創建這個實例; 三是它必須自行向整個系統提供這個實例。 單例模式的要點有三個: 為什麼要使用PHP單例模式 2.簡單工廠模式 ①抽象基類:類中定義抽象一些方法,用以在子類中實現 ②繼承自抽象基類的子類:實現基類中的抽象方法 ③工廠類: ...
  • 【上海尚學堂的話】:本文主要講述了Mashape的首席技術執行官Palladino對API網關的詳細介紹,以及API網關在微服務中所起的作用,同時介紹了Mashape的一款開源API網關Kong。 API網關提供商Mashape的首席技術執行官Marco Palladino預測,儘管它們在命名方面存 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...