jQuery-File-Upload 使用,jQuery-File-Upload上傳插件

来源:https://www.cnblogs.com/fanshuyao/archive/2020/01/10/12174802.html
-Advertisement-
Play Games

©Copyright 蕃薯耀 2020-01-10 https://www.cnblogs.com/fanshuyao/ 一、官網地址: https://github.com/blueimp/jQuery-File-Upload 二、使用文檔(參數說明) https://github.com/blu ...


================================

©Copyright 蕃薯耀 2020-01-10

https://www.cnblogs.com/fanshuyao/

 

一、官網地址:

https://github.com/blueimp/jQuery-File-Upload

 

二、使用文檔(參數說明)

https://github.com/blueimp/jQuery-File-Upload/wiki/Options

 

三、瀏覽器支持(官網說明)

  • Google Chrome
  • Apple Safari 4.0+
  • Mozilla Firefox 3.0+
  • Opera 11.0+
  • Microsoft Internet Explorer 6.0+

 

四、jQuery-File-Upload 入門使用

 

1、最簡單的使用方法:

<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<title>jQuery File Upload Example</title>
</head>
<body>
<input id="fileupload" type="file" name="files[]" data-url="server/php/" multiple>
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script src="js/vendor/jquery.ui.widget.js"></script>
<script src="js/jquery.iframe-transport.js"></script>
<script src="js/jquery.fileupload.js"></script>
<script>
$(function () {
    $('#fileupload').fileupload({
        dataType: 'json',
        done: function (e, data) {
            $.each(data.result.files, function (index, file) {
                $('<p/>').text(file.name).appendTo(document.body);
            });
        }
    });
});
</script>
</body> 
</html>

 

如果不使用iframe,jquery.iframe-transport.js文件可以不引用。

 

2、自定義使用

不顯示文件選擇框,只顯示上傳按鈕

<a id="btnUploadMdbFile" href="javascript:;" class="plui-linkbutton" >上傳mdb文件</a> 

<div style="display: none;">        
    <input id="inputUploadMdbFile" type="file" name="mdbFiles" />
</div>

 

控制項初始化:

$(function(){
    
    $("#btnUploadMdbFile").click(function(){
        $("#inputUploadMdbFile").click();
    });
    
    //multiple 多選
    //input限制文件上傳可以使用(IE9+): accept="application/msaccess" accept="image/*"
    $("#inputUploadMdbFile").fileupload({
        url : "${pageContext.request.contextPath}/xxx/fileUploadAction.go?method=fileUpload",
        dataType: "json",
        //autoUpload: false,
        formData: {
            "dirPath" : "temp_dir/mdb/"
        },
        add: function(e, data){
            //var acceptFileTypes = /^(gif|jpe?g|png)$/i;
            var acceptFileTypes = /^mdb$/i;
            var files = data.originalFiles;
            if(files && files.length > 0){
                var isPass = true;
                for(var i=0; i<files.length; i++){
                    var name = files[i]["name"];
                    var lastIndex = name.lastIndexOf(".");
                    if(lastIndex < 0){
                        isPass = false;
                        break;
                    }else{
                        var fileType = name.substring(lastIndex + 1);
                        if(!acceptFileTypes.test(fileType)){
                            isPass = false;
                            break;
                        }
                    }
                }
                if(!isPass){
                    top.$.messager.alert("系統提示","只能上傳*.mdb文件","info"); 
                    return;
                }
                data.submit();
            }
        },
        done: function(e, data){
            //alert($.toJSON(data.result));
            if(data.result && data.result.files && data.result.files.length > 0){
                var file = data.result.files[0];
                if(file.suffix == ".mdb"){
                    dealMdbFile(file.absolutePath);
                }else{
                    top.$.messager.alert("系統提示","只能上傳*.mdb文件","info"); 
                }
            }
        }
    });
    
});

 

formData:可以傳遞自己的參數。

add: function(e, data){}:增加控制文件的類型限制,這個可以省略。

done: function(e, data){}:上傳成功後結果返回處理。

 

更多參數設置見:

https://github.com/blueimp/jQuery-File-Upload/wiki/Options

 

(如果你覺得文章對你有幫助,歡迎捐贈,^_^,謝謝!) 

================================

©Copyright 蕃薯耀 2020-01-10

https://www.cnblogs.com/fanshuyao/

 


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

-Advertisement-
Play Games
更多相關文章
  • 一、vue組件中的data為什麼是函數 為了保證組件的獨立性 和 可 復用性,data 是一個函數,組件實例化的時候這個函數將會被調用,返回一個對象,電腦會給這個對象分配一個記憶體地址,你實例化幾次,就分配幾個記憶體地址,他們的地址都不一樣,所以每個組件中的數據不會相互干擾,改變其中一個組件的狀態,其 ...
  • Vuex 一、基礎 1. Vuex 相當於 vue的數據倉庫 2. Vuex 是 vue 的狀態管理工具 3. Vuex中的 state 只能通過mutations 改變 4. Vuex很適合做購物車 什麼是Vuex? Vuex採用集中式存儲所有組件的數據狀態,並且中間狀態和store(後臺數據)是 ...
  • 1. 為什麼觸發不了了? <button type="button" onclick="a()">button</button> 全形字元 全形空格可能在輸入的時候無意識觸發, 在 js 里基本沒有影響, 但是在 HTML 標簽裡面屬性之間可能就難以發現, 導致全形空格後面的屬性失效. 雖然全形字元 ...
  • 舊的模板消息將在 2020 年 1 月 10 號全面下架,也就是今天,不過貌似現在還可以用!!!我已經改好了,只不過還沒有上線,準備堅持到最後一天! 0、訂閱消息 簡單介紹一下訂閱消息的特點: 用戶授權就能發送訂閱消息,一次授權可下發一次信息,長期訂閱消息模板授權一次理論上可以無限下發消息 與舊模板 ...
  • 簡單點說,組件是要復用的,在很多地方都會調用。 如果data不是函數,而是屬性,就又可能會發生多個地方的相同組件操作同一個Data屬性,導致數據混亂。 而如果是函數,因為組件data函數的返回值是{屬性:屬性名},所以每次返回都會在堆空間創建一個新的空間,所以各個組件不會發生操作同一個數據,防止數據 ...
  • 沙箱 沙箱: 環境, 黑盒, 在一個虛擬的環境中模擬真實世界, 做實驗, 實驗結果和真實世界的結果是一樣, 但是不會影響真實世界 全局變數 var num=10; console.log(num+10); //沙箱 小環境 (function () { var num = 10; console.l ...
  • 導航守衛 一、全局導航守衛 1. 全局導航守衛,把方法給 router,只要路由發生改變跳轉都會觸發這個函數 2. 每個路由 都有一個 meta 3. 全局導航守衛分兩種: 1. 全局前置導航守衛:路由還沒有跳轉之前 2. 全局後置導航守衛:路由跳轉之後 3. to 和 from 都是 router ...
  • 路由的緩存 路由緩存是 Vue組件優化的一個重要方法 為什麼實現路由緩存? 為了 組件間 相互切換不會重覆載入數據,影響用戶體驗,我們通常需要將組件的數組實現緩存,當我們點過來,在點的時候會再次發送 ajax,想讓它發送之後把數據存起來。 我們需要,當我點擊的時候直接出來 <keep-alive> ...
一周排行
    -Advertisement-
    Play Games
  • Timer是什麼 Timer 是一種用於創建定期粒度行為的機制。 與標準的 .NET System.Threading.Timer 類相似,Orleans 的 Timer 允許在一段時間後執行特定的操作,或者在特定的時間間隔內重覆執行操作。 它在分散式系統中具有重要作用,特別是在處理需要周期性執行的 ...
  • 前言 相信很多做WPF開發的小伙伴都遇到過表格類的需求,雖然現有的Grid控制項也能實現,但是使用起來的體驗感並不好,比如要實現一個Excel中的表格效果,估計你能想到的第一個方法就是套Border控制項,用這種方法你需要控制每個Border的邊框,並且在一堆Bordr中找到Grid.Row,Grid. ...
  • .NET C#程式啟動閃退,目錄導致的問題 這是第2次踩這個坑了,很小的編程細節,容易忽略,所以寫個博客,分享給大家。 1.第一次坑:是windows 系統把程式運行成服務,找不到配置文件,原因是以服務運行它的工作目錄是在C:\Windows\System32 2.本次坑:WPF桌面程式通過註冊表設 ...
  • 在分散式系統中,數據的持久化是至關重要的一環。 Orleans 7 引入了強大的持久化功能,使得在分散式環境下管理數據變得更加輕鬆和可靠。 本文將介紹什麼是 Orleans 7 的持久化,如何設置它以及相應的代碼示例。 什麼是 Orleans 7 的持久化? Orleans 7 的持久化是指將 Or ...
  • 前言 .NET Feature Management 是一個用於管理應用程式功能的庫,它可以幫助開發人員在應用程式中輕鬆地添加、移除和管理功能。使用 Feature Management,開發人員可以根據不同用戶、環境或其他條件來動態地控制應用程式中的功能。這使得開發人員可以更靈活地管理應用程式的功 ...
  • 在 WPF 應用程式中,拖放操作是實現用戶交互的重要組成部分。通過拖放操作,用戶可以輕鬆地將數據從一個位置移動到另一個位置,或者將控制項從一個容器移動到另一個容器。然而,WPF 中預設的拖放操作可能並不是那麼好用。為瞭解決這個問題,我們可以自定義一個 Panel 來實現更簡單的拖拽操作。 自定義 Pa ...
  • 在實際使用中,由於涉及到不同編程語言之間互相調用,導致C++ 中的OpenCV與C#中的OpenCvSharp 圖像數據在不同編程語言之間難以有效傳遞。在本文中我們將結合OpenCvSharp源碼實現原理,探究兩種數據之間的通信方式。 ...
  • 一、前言 這是一篇搭建許可權管理系統的系列文章。 隨著網路的發展,信息安全對應任何企業來說都越發的重要,而本系列文章將和大家一起一步一步搭建一個全新的許可權管理系統。 說明:由於搭建一個全新的項目過於繁瑣,所有作者將挑選核心代碼和核心思路進行分享。 二、技術選擇 三、開始設計 1、自主搭建vue前端和. ...
  • Csharper中的表達式樹 這節課來瞭解一下表示式樹是什麼? 在C#中,表達式樹是一種數據結構,它可以表示一些代碼塊,如Lambda表達式或查詢表達式。表達式樹使你能夠查看和操作數據,就像你可以查看和操作代碼一樣。它們通常用於創建動態查詢和解析表達式。 一、認識表達式樹 為什麼要這樣說?它和委托有 ...
  • 在使用Django等框架來操作MySQL時,實際上底層還是通過Python來操作的,首先需要安裝一個驅動程式,在Python3中,驅動程式有多種選擇,比如有pymysql以及mysqlclient等。使用pip命令安裝mysqlclient失敗應如何解決? 安裝的python版本說明 機器同時安裝了 ...