本發(fā)明涉及計算機應用技術領域,特別涉及一種調用上傳組件的裝置、方法和系統(tǒng)。
背景技術:
近年來隨著前端應用的發(fā)展,出現(xiàn)了各式各樣的上傳組件供應用開發(fā)者選擇,在應用開發(fā)者選定上傳組件后,需要針對自己開發(fā)的應用自定義上傳組件的各種參數(shù),對于需要多個上傳組件的應用來說,應用開發(fā)者需要為每一個上傳組件配置各種參數(shù),由于配置的參數(shù)中常常包含有一些復雜度較高的參數(shù),需要消耗應用開發(fā)者較長的時間為每一個上傳組件配置參數(shù),造成應用開發(fā)的效率較低。
技術實現(xiàn)要素:
本發(fā)明實施例提供了一種調用上傳組件的裝置、方法和系統(tǒng),能夠有效的提高應用開發(fā)的效率。
一種調用上傳組件的裝置,與外設的至少一種上傳組件相連,包括:封裝構建單元、交互單元和接口,其中,
所述封裝構建單元,用于確定外設的每一種上傳組件對應的默認參數(shù)和默認值,對所述默認參數(shù)和默認值進行封裝;
所述交互單元,用于確定調變參數(shù),接收輸入的所述調變參數(shù)對應的參數(shù)值,并發(fā)送所述調變參數(shù)對應的參數(shù)值;
所述接口,用于加載所述封裝構建單元封裝的默認參數(shù)和對應的默認值,接收并解析所述交互單元發(fā)送的所述調變參數(shù)對應的參數(shù)值,根據(jù)所述默認值和解析出的參數(shù)值,調用外設的目標上傳組件。
優(yōu)選地,上述裝置進一步包括:顯示單元,其中,
所述封裝構建單元,進一步用于封裝至少一種文件上傳的方式和樣式,為所述封裝的至少一種文件上傳的方式和樣式中每一種文件上傳的方式和樣式構建對應的html元素屬性;
所述交互單元,進一步用于接收輸入的至少一個目標html元素屬性值,并發(fā)送所述至少一個目標html元素屬性值;
所述接口,進一步用于接收所述交互單元發(fā)送的至少一個目標html元素屬性值,解析所述至少一個目標html元素屬性值,根據(jù)所述至少一個目標html元素屬性值,在所述封裝構建單元封裝的至少一種文件上傳的方式和樣式中,選定文件上傳的目標方式和樣式,并將所述文件上傳的目標方式和樣式發(fā)送給所述外設的目標上傳組件;
所述顯示單元,用于根據(jù)所述外設的目標上傳組件和所述接口接收到的文件上傳的目標方式和樣式,顯示文件上傳的對話框和文件上傳的按鈕。
優(yōu)選地,所述封裝構建單元,用于將外設的每一種上傳組件對應的默認參數(shù)和默認值封裝到對應的webuploader.js文件中,并存儲所述webuploader.js文件;
所述交互單元,用于確定文件上傳的服務器端地址和文件上傳的請求參數(shù)表為調變參數(shù),接收所述文件上傳的服務器端地址和文件上傳的請求參數(shù)表對應的參數(shù)值;
所述接口,進一步用于設置每一個webuploader.js文件對應的引入路徑,根據(jù)所述引入路徑,加載webuploader.js文件。
優(yōu)選地,所述封裝構建單元,用于封裝單文件上傳方式和樣式、多文件上傳方式和樣式、單圖片上傳方式和樣式及多圖片上傳方式和樣式,其中,單文件上傳方式和樣式/單圖片上傳方式和樣式,包括:在元素的右側添加“選擇”按鈕,當選中文件后添加“上傳”、“刪除”按鈕并隱藏“選擇”按鈕,并顯示上傳進度;多文件上傳方式和樣式/多圖片上傳方式和樣式,包括:為元素添加“添加文件”按鈕、“開始上傳”按鈕和“取消”按鈕,通過“添加文件”按鈕添加至少一個文件,并顯示上傳進度。
一種調用上傳組件的方法,連接至少一種上傳組件,確定每一種上傳組件對應的默認參數(shù)和默認值,對所述默認參數(shù)和默認值進行封裝;還包括:
確定調變參數(shù),接收輸入的所述調變參數(shù)對應的參數(shù)值;
加載所述封裝的默認參數(shù)和對應的默認值,并解析所述調變參數(shù)對應的參數(shù)值;
根據(jù)所述默認值和解析出的參數(shù)值,調用外設的目標上傳組件。
優(yōu)選地,上述方法進一步包括:封裝至少一種文件上傳的方式和樣式,為所述封裝的至少一種文件上傳的方式和樣式中每一種文件上傳的方式和樣式構建對應的html元素屬性;
在所述接收輸入的所述調變參數(shù)對應的參數(shù)值之后,在所述加載所述封裝的默認參數(shù)和對應的默認值之前,進一步包括:接收輸入的至少一個目標html元素屬性值;
在所述解析所述調變參數(shù)對應的參數(shù)值之后,在所述調用外設的目標上傳組件之前,進一步包括:解析所述至少一個目標html元素屬性值,根據(jù)所述至少一個目標html元素屬性值,在所述至少一種文件上傳的方式和樣式中,選定文件上傳的目標方式和樣式;
在所述調用外設的目標上傳組件之后,進一步包括:將所述文件上傳的目標方式和樣式發(fā)送給所述外設的目標上傳組件,根據(jù)所述文件上傳的目標方式和樣式,顯示文件上傳的對話框和文件上傳的按鈕。
優(yōu)選地,所述對所述默認參數(shù)和默認值進行封裝,包括:將默認參數(shù)和默認值封裝到對應的webuploader.js文件中,并存儲所述webuploader.js文件;
所述確定調變參數(shù),接收輸入的所述調變參數(shù)對應的參數(shù)值,包括:確定文件上傳的服務器端地址和文件上傳的請求參數(shù)表為調變參數(shù),接收所述文件上傳的服務器端地址和文件上傳的請求參數(shù)表對應的參數(shù)值;
所述加載所述封裝的默認參數(shù),包括:設置每一個webuploader.js文件對應的引入路徑,根據(jù)所述引入路徑,加載webuploader.js文件。
優(yōu)選地,所述至少一種文件上傳的方式和樣式,包括:
封裝單文件上傳方式和樣式、多文件上傳方式和樣式、單圖片上傳方式和樣式及多圖片上傳方式和樣式中的任意一種或多種。
一種調用上傳組件的系統(tǒng),包括:上述任意一種調用上傳組件的裝置和至少一種上傳組件,其中,
所述至少一種上傳組件中,每一種上傳組件,用于接收所述調用上傳組件的裝置的調用,并根據(jù)所述調用上傳組件的裝置封裝至少一種文件上傳的方式和樣式,輸出文件上傳/圖片上傳對話框。
優(yōu)選地,所述至少一種上傳組件,包括:Web Uploader和JS中的任意一種或兩種。
本發(fā)明實施例提供了一種調用上傳組件的裝置、方法和系統(tǒng),該裝置通過封裝構建單元確定外設的每一種上傳組件對應的默認參數(shù)和默認值,對默認參數(shù)和默認值進行封裝,實現(xiàn)了對默認參數(shù)和默認值的封裝,可以通過直接調用封裝好的默認參數(shù)和默認值,而無須用戶輸入,另外,通過交互單元可以接收需要調變的參數(shù)對應的參數(shù)值,從而通過接口調用外設的目標上傳組件,通過直接調用封裝好的默認參數(shù),而無須用戶依次編寫參數(shù),從而能夠有效的提高應用開發(fā)的效率。
附圖說明
為了更清楚地說明本發(fā)明實施例或現(xiàn)有技術中的技術方案,下面將對實施例或現(xiàn)有技術描述中所需要使用的附圖作簡單地介紹,顯而易見地,下面描述中的附圖是本發(fā)明的一些實施例,對于本領域普通技術人員來講,在不付出創(chuàng)造性勞動的前提下,還可以根據(jù)這些附圖獲得其他的附圖。
圖1是本發(fā)明一個實施例提供的一種調用上傳組件的裝置的結構示意圖;
圖2是本發(fā)明另一實施例提供的一種調用上傳組件的裝置的結構示意圖;
圖3是本發(fā)明一個實施例提供的一種調用上傳組件的方法的流程圖;
圖4是本發(fā)明另一個實施例提供的一種調用上傳組件的方法的流程圖;
圖5是本發(fā)明一個實施例提供的一種上傳組件的顯示樣式的示意圖;
圖6是本發(fā)明一個實施例提供的一種調用上傳組件的系統(tǒng)的結構示意圖。
具體實施方式
為使本發(fā)明實施例的目的、技術方案和優(yōu)點更加清楚,下面將結合本發(fā)明實施例中的附圖,對本發(fā)明實施例中的技術方案進行清楚、完整地描述,顯然,所描述的實施例是本發(fā)明一部分實施例,而不是全部的實施例,基于本發(fā)明中的實施例,本領域普通技術人員在沒有做出創(chuàng)造性勞動的前提下所獲得的所有其他實施例,都屬于本發(fā)明保護的范圍。
如圖1所示,本發(fā)明實施例提供一種調用上傳組件的裝置,與外設的至少一種上傳組件相連,包括:封裝構建單元101、交互單元102和接口103,其中,
封裝構建單元101,用于確定外設的每一種上傳組件對應的默認參數(shù)和默認值,對默認參數(shù)和默認值進行封裝;
交互單元102,用于確定調變參數(shù),接收輸入的調變參數(shù)對應的參數(shù)值,并發(fā)送調變參數(shù)對應的參數(shù)值;
接口103,用于加載封裝構建單元101封裝的默認參數(shù)和對應的默認值,接收并解析交互單元102發(fā)送的調變參數(shù)對應的參數(shù)值,根據(jù)默認值和解析出的參數(shù)值,調用外設的目標上傳組件。
在圖1所示的實施例中,通過封裝構建單元確定外設的每一種上傳組件對應的默認參數(shù)和默認值,對默認參數(shù)和默認值進行封裝,實現(xiàn)了對默認參數(shù)和默認值的封裝,可以通過直接調用封裝好的默認參數(shù)和默認值,而無須用戶輸入,另外,通過交互單元可以接收需要調變的參數(shù)對應的參數(shù)值,從而通過接口調用外設的目標上傳組件,通過直接調用封裝好的默認參數(shù),而無須用戶依次編寫參數(shù),能夠有效的提高應用開發(fā)的效率。
如圖2所示,在本發(fā)明另一實施例中,上述裝置進一步包括:顯示單元201,其中,
封裝構建單元101,進一步用于封裝至少一種文件上傳的方式和樣式,為封裝的至少一種文件上傳的方式和樣式中每一種文件上傳的方式和樣式構建對應的html元素屬性;
交互單元102,進一步用于接收輸入的至少一個目標html元素屬性值,并發(fā)送至少一個目標html元素屬性值;
接口103,進一步用于接收交互單元102發(fā)送的至少一個目標html元素屬性值,解析至少一個目標html元素屬性值,根據(jù)至少一個目標html元素屬性值,在封裝構建單元101封裝的至少一種文件上傳的方式和樣式中,選定文件上傳的目標方式和樣式,并將文件上傳的目標方式和樣式發(fā)送給外設的目標上傳組件;
顯示單元201,用于根據(jù)外設的目標上傳組件和接口103接收到的文件上傳的目標方式和樣式,顯示文件上傳的對話框和文件上傳的按鈕。
在本發(fā)明又一實施例中,封裝構建單元,用于將外設的每一種上傳組件對應的默認參數(shù)和默認值封裝到對應的webuploader.js文件中,并存儲webuploader.js文件;
交互單元,用于確定文件上傳的服務器端地址和文件上傳的請求參數(shù)表為調變參數(shù),接收文件上傳的服務器端地址和文件上傳的請求參數(shù)表對應的參數(shù)值;
接口,進一步用于設置每一個webuploader.js文件對應的引入路徑,根據(jù)引入路徑,加載webuploader.js文件。
在本發(fā)明另一實施例中,封裝構建單元,用于封裝單文件上傳方式和樣式、多文件上傳方式和樣式、單圖片上傳方式和樣式及多圖片上傳方式和樣式,其中,單文件上傳方式和樣式/單圖片上傳方式和樣式,包括:在元素的右側添加“選擇”按鈕,當選中文件后添加“上傳”、“刪除”按鈕并隱藏“選擇”按鈕,并顯示上傳進度;多文件上傳方式和樣式/多圖片上傳方式和樣式,包括:為元素添加“添加文件”按鈕、“開始上傳”按鈕和“取消”按鈕,通過“添加文件”按鈕添加至少一個文件,并顯示上傳進度。
如圖3所示,本發(fā)明實施例提供一種調用上傳組件的方法,該方法可以包括以下步驟:
步驟301:連接至少一種上傳組件,確定每一種上傳組件對應的默認參數(shù)和默認值,對默認參數(shù)和默認值進行封裝;
步驟302:確定調變參數(shù),接收輸入的調變參數(shù)對應的參數(shù)值;
步驟303:加載封裝的默認參數(shù)和對應的默認值,并解析調變參數(shù)對應的參數(shù)值;
步驟304:根據(jù)默認值和解析出的參數(shù)值,調用外設的目標上傳組件。
在本發(fā)明一個實施例中,通過封裝至少一種文件上傳的方式和樣式,以進一步提高應用開發(fā)的效率,上述方法進一步包括:封裝至少一種文件上傳的方式和樣式,為封裝的至少一種文件上傳的方式和樣式中每一種文件上傳的方式和樣式構建對應的html元素屬性;在步驟302之后,步驟303之前,進一步包括:接收輸入的至少一個目標html元素屬性值;在步驟303之后,步驟304之前,進一步包括:解析至少一個目標html元素屬性值,根據(jù)至少一個目標html元素屬性值,在至少一種文件上傳的方式和樣式中,選定文件上傳的目標方式和樣式;在步驟304之后進一步包括:將文件上傳的目標方式和樣式發(fā)送給外設的目標上傳組件,根據(jù)文件上傳的目標方式和樣式,顯示文件上傳的對話框和文件上傳的按鈕。例如:用戶只需要輸入<input type=“mutilate-files”>,即可選定多文件上傳方式和樣式,然后輸出該多文件上傳方式和樣式,用以接收上傳文件,進行文件上傳。
在本發(fā)明一個實施例中,為了能夠方便便捷的獲得默認參數(shù)和默認值,同時靈活的根據(jù)用戶需求進行設置,步驟301的具體實施方式,包括:將默認參數(shù)和默認值封裝到對應的webuploader.js文件中,并存儲所述webuploader.js文件;步驟302的具體實施方式,包括:確定文件上傳的服務器端地址和文件上傳的請求參數(shù)表為調變參數(shù),接收文件上傳的服務器端地址和文件上傳的請求參數(shù)表對應的參數(shù)值;步驟303的具體實施方式,包括:設置每一個webuploader.js文件對應的引入路徑,根據(jù)引入路徑,加載webuploader.js文件。通過該過程,當webuploader.js文件路徑發(fā)生變化時,只需要修改引入路徑,即可實現(xiàn)加載webuploader.js文件,另外由于不同文件上傳的服務器的地址不同,通過將文件上傳的服務器地址設置為調變參數(shù),用戶即可根據(jù)自己的需求輸入,使得調用上傳組件更加靈活。
在本發(fā)明一個實施例中,為了保證上傳方式和樣式的多樣性,以供按照用戶需求進行選擇,上述至少一種文件上傳的方式和樣式,包括:封裝單文件上傳方式和樣式、多文件上傳方式和樣式、單圖片上傳方式和樣式及多圖片上傳方式和樣式中的任意一種或多種。例如:單文件上傳方式和樣式/單圖片上傳方式和樣式可以設置為在元素的右側添加“選擇”按鈕,當選中文件后添加“上傳”、“刪除”按鈕并隱藏“選擇”按鈕,并顯示上傳進度;多文件上傳方式和樣式/多圖片上傳方式和樣式可以設置為元素添加“添加文件”按鈕、“開始上傳”按鈕和“取消”按鈕,通過“添加文件”按鈕添加至少一個文件,并顯示上傳進度。
如圖4所示,本發(fā)明另一實施例提供了一種調用上傳組件的方法,該方法可以包括以下步驟:
步驟401:連接至少一種上傳組件,確定每一種上傳組件對應的默認參數(shù)和默認值;
步驟402:將默認參數(shù)和默認值封裝到webuploader.js文件;
在步驟401和步驟402中通過連接至少一種上傳組件如Web Uploader或JS,那么根據(jù)應用開發(fā)過程中的需求可以實現(xiàn)對多種上傳組件的調用,由于每一種上傳組件的參數(shù)不同,需要為不同的組件分別確定對應的默認參數(shù)和默認值,例如:對于Web Uploader來說,disableGlobalDnd默認值為false(默認禁止拖拽,以防把圖片拖入瀏覽器而被當做文件打開),還可以把一些不常用的參數(shù)或者應用對上傳需求固定的參數(shù)設為默認參數(shù),并賦予默認值,還可以根據(jù)應用的實際需求配置默認參數(shù)項。形式如下:
另外,在該步驟中,通過將將默認參數(shù)和默認值封裝到webuploader.js文件,用戶只需要確定或者修改webuploader.js文件的存儲路徑,即可自動實現(xiàn)加載默認參數(shù)和默認值,而再無需用戶輸入這部分參數(shù)值。
步驟403:設置每一個webuploader.js文件對應的引入路徑;
該步驟得引入路徑即webuploader.js文件的存儲路徑,通過該引入路徑能夠在后續(xù)過程中成功對webuploader.js文件中的默認參數(shù)和默認值進行加載。
步驟404:封裝至少一種文件上傳的方式和樣式;
在該步驟中封裝的文件上傳的方式和樣式,包括:單文件上傳方式和樣式、多文件上傳方式和樣式、單圖片上傳方式和樣式及多圖片上傳方式和樣式中的任意一種或多種,其中,單文件上傳方式和樣式/單圖片上傳方式和樣式為在元素的右側添加“選擇”按鈕,當選中文件后添加“上傳”、“刪除”按鈕并隱藏“選擇”按鈕,并顯示上傳進度;多文件上傳方式和樣式/多圖片上傳方式和樣式為元素添加“添加文件”按鈕、“開始上傳”按鈕和“取消”按鈕,通過“添加文件”按鈕添加至少一個文件,并顯示上傳進度。提及的元素文件的顯示框。
步驟405:為封裝的至少一種文件上傳的方式和樣式中每一種文件上傳的方式和樣式構建對應的html元素屬性;
在該步驟中,對應于單文件上傳方式和樣式、多文件上傳方式和樣式、單圖片上傳方式和樣式及多圖片上傳方式和樣式的元素屬性分別為file、mutilate-files、image、mutilate-images四種,其輸入形式如下所示:
<input type=“file”…>、<input type=“mutilate-files”…>等。
步驟406:確定調變參數(shù),接收輸入的調變參數(shù)對應的參數(shù)值;
在該步驟中確定的調變參數(shù)主要是一些簡單的,用戶容易記住的參數(shù),如:文件上傳的服務器端地址(server),文件上傳的請求參數(shù)表(formData)等,該調變參數(shù)能夠滿足用戶的需求,保證了調用上傳組件的靈活性。例如:設置文件上傳的服務器端地址(server):
步驟407:接收輸入的至少一個目標html元素屬性值;
例如:用戶想要單文件上傳方式和樣式,則輸入<input type=“file”…>。
步驟408:根據(jù)引入路徑,加載webuploader.js文件,并解析調變參數(shù)對應的參數(shù)值;
步驟409:根據(jù)默認值和解析出的參數(shù)值,調用外設的目標上傳組件;
步驟408和步驟409的過程實現(xiàn)了通過參數(shù)值調用上傳組件,但是,上傳組件的顯示樣式則需要下述步驟410至步驟413實現(xiàn)。
步驟410:解析至少一個目標html元素屬性值;
步驟411:根據(jù)至少一個目標html元素屬性值,在至少一種文件上傳的方式和樣式中,選定文件上傳的目標方式和樣式;
步驟412:將文件上傳的目標方式和樣式發(fā)送給外設的目標上傳組件;
步驟413:根據(jù)文件上傳的目標方式和樣式,顯示文件上傳的對話框和文件上傳的按鈕。
步驟410至步驟413的實現(xiàn)過程:例如:解析出兩個目標html元素屬性值,均為<input type=“file”…>即單文件上傳方式和樣式,則根據(jù)應用需求和前面參數(shù)的設置,將這兩個單文件上傳方式和樣式分別顯示在應用的不同位置,該單文件上傳方式和樣式的顯示形式如圖5所示,在未加載文件之前,在顯示框的右側顯示添加的“選擇”按鈕(圖5-1),當選中文件f123.zip后,添加“上傳”、“刪除”按鈕并隱藏“選擇”按鈕(圖5-2)。
如圖6所示,本發(fā)明實施例提供一種調用上傳組件的系統(tǒng),該系統(tǒng)包括:上述任意一種調用上傳組件的裝置601和至少一種上傳組件602,其中,
至少一種上傳組件602中,每一種上傳組件,用于接收調用上傳組件的裝置601的調用,并根據(jù)調用上傳組件的裝置601封裝至少一種文件上傳的方式和樣式,輸出文件上傳/圖片上傳對話框。
在本發(fā)明另一實施例中,上述至少一種上傳組件,包括:Web Uploader和JS中的任意一種或兩種。
根據(jù)上述方案,本發(fā)明的各實施例,至少具有如下有益效果:
1.通過封裝構建單元確定外設的每一種上傳組件對應的默認參數(shù)和默認值,對默認參數(shù)和默認值進行封裝,實現(xiàn)了對默認參數(shù)和默認值的封裝,可以通過直接調用封裝好的默認參數(shù)和默認值,而無須用戶輸入,另外,通過交互單元可以接收需要調變的參數(shù)對應的參數(shù)值,從而通過接口調用外設的目標上傳組件,通過直接調用封裝好的默認參數(shù),而無須用戶依次編寫參數(shù),能夠有效的提高應用開發(fā)的效率。
2.通過封裝至少一種文件上傳的方式和樣式,為封裝的至少一種文件上傳的方式和樣式中每一種文件上傳的方式和樣式構建對應的html元素屬性,通過接收輸入的至少一個目標html元素屬性值,解析至少一個目標html元素屬性值,即可在所述至少一種文件上傳的方式和樣式中,選定文件上傳的目標方式和樣式;也就是說,用戶只需要輸入元素屬性值即可定位出對應的文件上傳的方式和樣式,進一步提高了應用開發(fā)的效率,另外,本發(fā)明實施例封裝了單文件上傳方式和樣式、多文件上傳方式和樣式、單圖片上傳方式和樣式及多圖片上傳方式和樣式中的任意一種或多種,統(tǒng)一了上傳組件的顯示樣式。
3.通過確定文件上傳的服務器端地址和文件上傳的請求參數(shù)表為調變參數(shù),接收用戶輸入的文件上傳的服務器端地址和文件上傳的請求參數(shù)表對應的參數(shù)值,使用戶能夠按照根據(jù)自己的需求設置服務器端地址和文件上傳的請求參數(shù),使得本發(fā)明實施例提供的調用上傳組件的裝置具有一定的靈活性,另外,通過webuploader.js文件封裝默認參數(shù),當webuploader.js文件存儲路徑發(fā)生變化,用戶只需要更改接口中的引入路徑,而無須對加載到上傳組件中的每一個參數(shù)的路徑進行更改,進一步減少了工作量,從而進一步提高了開發(fā)效率。
需要說明的是,在本文中,諸如第一和第二之類的關系術語僅僅用來將一個實體或者操作與另一個實體或操作區(qū)分開來,而不一定要求或者暗示這些實體或操作之間存在任何這種實際的關系或者順序。而且,術語“包括”、“包含”或者其任何其他變體意在涵蓋非排他性的包含,從而使得包括一系列要素的過程、方法、物品或者設備不僅包括那些要素,而且還包括沒有明確列出的其他要素,或者是還包括為這種過程、方法、物品或者設備所固有的要素。在沒有更多限制的情況下,由語句“包括一個······”限定的要素,并不排除在包括所述要素的過程、方法、物品或者設備中還存在另外的相同因素。
本領域普通技術人員可以理解:實現(xiàn)上述方法實施例的全部或部分步驟可以通過程序指令相關的硬件來完成,前述的程序可以存儲在計算機可讀取的存儲介質中,該程序在執(zhí)行時,執(zhí)行包括上述方法實施例的步驟;而前述的存儲介質包括:ROM、RAM、磁碟或者光盤等各種可以存儲程序代碼的介質中。
最后需要說明的是:以上所述僅為本發(fā)明的較佳實施例,僅用于說明本發(fā)明的技術方案,并非用于限定本發(fā)明的保護范圍。凡在本發(fā)明的精神和原則之內所做的任何修改、等同替換、改進等,均包含在本發(fā)明的保護范圍內。