Blazor 使用拖放(drag and drop)上傳文件 , 粘貼文件上傳

来源:https://www.cnblogs.com/densen2014/archive/2022/04/11/16128246.html
-Advertisement-
Play Games

在很多上傳文件的應用實例中, 都可以看到[拖放文件到此上傳]這種騷功能 ,今天我們就來試試Blazor能不能完成這個想法. 原文鏈接:https://www.cnblogs.com/densen2014/p/16128246.html 簡述HTML5拖放 拖放是HTML5標準的一部分,任何元素都能夠 ...


在很多上傳文件的應用實例中, 都可以看到[拖放文件到此上傳]這種騷功能 ,今天我們就來試試Blazor能不能完成這個想法.

原文鏈接:https://www.cnblogs.com/densen2014/p/16128246.html

簡述HTML5拖放

拖放是HTML5標準的一部分,任何元素都能夠拖放,也能夠將本地的文件拖放到頁面上。

設置元素可拖放

為了使元素可拖動,把 draggable 屬性設置為 true

<img draggable="true" />

拖放事件

有7個拖放事件可以捕獲,如下:

dragstart:開始拖元素觸發

dragenter:元素拖進可drop元素(綁定drop事件的元素)時觸發

dragover:當元素拖動到drop元素上時觸發

drop:當元素放下到drop元素觸發

dragleave :當元素離開drop元素時觸發

drag:每次元素被拖動時會觸發

dragend:放開拖動元素時觸發

完成一次拖放的事件過程是: dragstart –> dragenter –> dragover –> drop –> dragend

瀏覽器支持

Edge、Firefox、Opera 12、Chrome 以及 Safari 5 支持拖放。

拖拽上傳實現

1.新建工程n02drag,將項目添加到解決方案中

dotnet new blazorserver -o n02drag
dotnet sln add n02drag/n02drag.csproj

2.在文件夾wwwroot/lib,添加drag子文件夾,新建app.js文件

先阻止頁面預設的拖放行為,不然頁面會被拖放的文件替換了。

//阻止瀏覽器預設行為
document.addEventListener( "dragleave", function(e) {
     e.preventDefault();
}, false);
document.addEventListener( "drop", function(e) {
     e.preventDefault();
}, false);
document.addEventListener( "dragenter", function(e) {
     e.preventDefault();
}, false);
document.addEventListener( "dragover", function(e) {
     e.preventDefault();
}, false);

設置drop區域

當文件拖放到drop區域時,就能觸發上傳。

    element.addEventListener("drop", function (e) {

        try {
            var fileList = e.dataTransfer.files; //獲取文件對象
            //檢測是否是拖拽文件到頁面的操作
            if (fileList.length == 0) {
                return false;
            }

            inputFile.files = e.dataTransfer.files;
            const event = new Event('change', { bubbles: true });
            inputFile.dispatchEvent(event);
        }
        catch (e) {
            wrapper.invokeMethodAsync('DropAlert', e);
        }
    }, false);

2.在文件Pages/Index.razor,添加上傳組件

頁面

@implements IAsyncDisposable
@inject IJSRuntime JS

<div @ref="UploadElement" style="padding: 20px; width: 200px; height: 200px; background-color: cornflowerblue; border: 2px dashed #0087F7; border-radius: 5px; ">
    <p>拖放上傳文件</p>
     <InputFile OnChange="OnChange" class="form-control" multiple @ref="inputFile"/>
</div>

<pre>
<code>
        @uploadstatus
</code>
</pre>

代碼

  1. InputFile 開啟 multiple ,接受多文件上傳
  2. 使用JS隔離技術
  3. Dispose處理回收

@code{
    [Inject] protected Microsoft.AspNetCore.Hosting.IWebHostEnvironment? HostEnvironment { get; set; } //獲取IWebHostEnvironment

    protected ElementReference UploadElement { get; set; }
    protected InputFile? inputFile { get; set; }

    private DotNetObjectReference<Index>? wrapper;

    private IJSObjectReference? module;
    private IJSObjectReference? dropInstance;

    protected string UploadPath = "";
    protected string? uploadstatus;
    long maxFileSize = 1024 * 1024 * 15;

    protected override void OnAfterRender(bool firstRender)
    {
        if (!firstRender) return;
        UploadPath = Path.Combine(HostEnvironment!.WebRootPath, "Upload"); //初始化上傳路徑
        if (!Directory.Exists(UploadPath)) Directory.CreateDirectory(UploadPath); //不存在則新建目錄
    }

    protected async Task OnChange(InputFileChangeEventArgs e)
    {
        int i = 0;
        var selectedFiles = e.GetMultipleFiles(100);
        foreach (var item in selectedFiles)
        {
            i++;
            await OnSubmit(item);
            uploadstatus += Environment.NewLine + $"[{i}]: " + item.Name;
        }
    }

    protected async Task OnSubmit(IBrowserFile efile)
    {
        if (efile == null) return;
        var tempfilename = Path.Combine(UploadPath, efile.Name);
        await using FileStream fs = new(tempfilename, FileMode.Create);
        using var stream = efile.OpenReadStream(maxFileSize);
        await stream.CopyToAsync(fs);
        StateHasChanged();
    }


    protected override async Task OnAfterRenderAsync(bool firstRender)
    {
        if (!firstRender) return;

        module = await JS.InvokeAsync<IJSObjectReference>("import", "./lib/drag/app.js");
        wrapper = DotNetObjectReference.Create(this);
        dropInstance = await module.InvokeAsync<IJSObjectReference>("init", wrapper , UploadElement, inputFile!.Element);
    }

    [JSInvokable]
    public void DropAlert(string msg)
    {
        uploadstatus  += Environment.NewLine + $"[!Alert!]: " + msg;
        StateHasChanged();
    }


    async ValueTask IAsyncDisposable.DisposeAsync()
    {
        if (dropInstance != null)
        {
            await dropInstance.InvokeVoidAsync("dispose");
            await dropInstance.DisposeAsync();
        }

        if (wrapper != null)
        {
            wrapper.Dispose();
        }

        if (module != null)
        {
            await module.DisposeAsync();
        }
    }

}

3.就這麼簡單嗎?我們還可以加上一些騷功能

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

-Advertisement-
Play Games
更多相關文章
  • 今天給大家分享一個數據平均值的吧,好像從來沒有分享過這個內容。 以問題為導向利用Python幫助我們解決在科研中遇到的問題。最近有同學在處理TRMM降水數據的時候,說是要提取每個月的均 值出來。數據格式是tif柵格,目的也是非常明確的:提取多個tif的降水柵格均值出來。 剛纔看了一下TRMM的計劃說 ...
  • 在學習python之前我們可以先學習一些Linux的簡單語法,幫助我們對python語句的編譯和執行有一個更好的理解,同時如果我們以後開發的python程式需要用到伺服器,可以直接用Linux搭建。 接下來我們就可以開始學習python了,python、Java和PHP等語言被稱為高級語言,C語言和 ...
  • 1,打包項目 把項目打成jar 2,配置idea遠程調試 我設置的是本地調試,遠程伺服器設置為遠程的伺服器和埠即可。 3, 伺服器啟動項目 啟動項目: java -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005 - ...
  • 原文鏈接:https://www.cnblogs.com/ysmc/p/16133351.html 在 Bootstrap 中,柵格相信大家都很熟悉,簡直就是佈局神器啊,Bootstrap Blazor 組件庫當然毫無意外地支持該功能,並且封裝成了組件,使用更加方便,下麵我們一起來看看吧! 首先,這 ...
  • 1.Redis介紹 REmote DIctionary Server(Redis) 是一個由Salvatore Sanfilippo寫的 key-value 存儲系統,是跨平臺的非關係型資料庫,Redis 是一個開源的使用 ANSI C 語言編寫、遵守 BSD 協議、支持網路、可基於記憶體、分散式、可 ...
  • 有沒有想過如果我們自己要設計一門編程語言,要做到什麼樣的標準才能符合在.Net平臺下運行的條件呢?.Net在官方描述過一段話,大體的意思變成白話是:只要你的語言在編譯後能夠轉換成CIL代碼,那麼你的語言就可以在.Net平臺下進行開發和運行。 CIL語言之所以能夠在.Net平臺下運行,實際上它是符合了 ...
  • Metalama是一個基於微軟編譯器Roslyn的元編程的庫,可以解決我在開發中遇到的重覆代碼的問題。但是其實Metalama不止可以提供編譯時的代碼轉換,更可以提供自定義代碼分析、與IDE結合的自定義代碼修複與代碼重構功能 等功能。 經過面對文檔的學習,發現Metalama可以做到很多非常神奇的事... ...
  • 由於部署個人博客系統的伺服器只有2G記憶體,每次利用jenkins編譯,發佈的時候jenkins老是掛,因此新買了一臺輕量應用伺服器,專門用於個人博客系統的持續發佈任務,下麵講解如何利用jenkins實現系統的持續發佈功能。 一、安裝Jenkins 我這邊伺服器是Linux CentOS 7 ,使用S ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...