HTML5向量實現檔案上傳進度條

2021-09-19 11:23:31 字數 4271 閱讀 2901

在html中,在檔案上傳的過程中,很多情況都是沒有任何的提示,這在體驗上很不好,使用者都不知道到時有沒有在上傳、上傳成功了沒有,所以今天給大家介紹的內容是通過ht for web向量來實現html5檔案上傳進度條,向量在《向量chart圖表嵌入html5網路拓撲圖的應用》一文中已經講述了關於setcomptype()方法的應用,今天我們用setimage()方法充分利用系統中定義好的向量資源來實現檔案上傳進度條,我們先來看下效果圖:

從效果圖可以看到,向伺服器上傳了乙個mp4檔案,並在最下方顯示當前上傳進度。

那麼接下來我們就來**下具體實現:

首先,我們來分析下進度條的結構:

需要乙個背景,background

需要乙個當前進度值,value

需要乙個前景,foreground,根據當前進度值,繪製前景,蓋過背景

結構就這麼簡單,那麼接下來就是具體的實現了,看碼:

ht.default.setimage('progress', ,

background : }

},// 繪製前景

,type : function(g, rect, comp, data, view) }]

});

我們定義了乙個名字為progress的向量物件,向量物件由兩部分組成,乙個是背景,乙個是前景。

繪製背景採用了資料繫結的方式,繫結了data的background屬性;繪製前景則採用自定義型別的方法繪製,是setcomptype()方法的一種縮寫,繪製是根據data中的value值計算繪製寬度。

向量的大體設計已經完成,那麼我們把他用起來,看看效果如何。

var datamodel = new ht.datamodel(),

node = new ht.node();

node.setvalue(0);

node.setimage('progress');

node.a('background', '#5f6870');

node.a('foreground', '#58b6da');

node.p(85, 87);

datamodel.add(node);

var graphview = new ht.graph.graphview(datamodel);

graphview.addtodom();

graphview.layout();

我們建立了乙個node,並將node的image屬性設定成我們定義的向量,然後建立乙個graphview元件,將node顯示在graphview網路拓撲圖中。

那麼接下來我們來模擬檔案上傳進度,讓進度條動起來。

function setprogressvalue(node) 

}

我們通過settimeout()方法不斷設定node的value值,但是,**執行起來你會發現,進度條根本沒有在動,一致處於初始狀態,當我們縮放graphview時,可以看到進度條在改變,這是為什麼呢?其實原因很簡單,我們在修改value值時,並沒有通知graphview要更新,因此進度條並不會因為node的value值改變而有所改變,那麼我們該如何通知graphview更新呢?方法很簡單,在修改node的value值後,派發乙個propertychange事件就可以了,在建立node**後新增如下**:

node.getvalue = function() ;

node.setvalue = function(value) ;

**中,通過fp()方法來派發propertychange事件,如此,進度條就可以正常工作,隨著node的value的變化而變化,效果圖如下:

但是還有一點不足,進度條雖然在跑了,但是我們還是不知道當前進度值是多少,只能通過進度條的比重來大致估計當前進度值,我們能否在進度條上新增乙個文字,用來顯示當前進度值呢,答案是肯定的,我們只需要在向量的comps中新增如下**就可以:

// 繪製文字

, type : 'text',

text : },

font : '12px arial, sans-ferif',

color : 'black'

}

**中同樣適用了繫結,繫結node當前的value值,具體的效果圖如下:

現在的進度條與最終效果就差圓角了,那麼圓角要如何實現呢?其實也不難,只需要繪製出乙個圓角矩形,並結合clip()方法將超出圓角矩形區域的部分擷取掉即可,clip()方法的詳細介紹可以參考mdn中的介紹。

首先,我們需要建立乙個揮之圓角矩形的方法:

/***

* 繪製圓邊矩形

* @param ctx 畫筆

* @param x 座標 x

* @param y 座標 y

* @param width 寬度

* @param height 高度

* @param radius 圓角半徑

*/function roundrect(ctx, x, y, width, height, radius)

採用自定義型別的方法,呼叫roundrect()方法,繪製乙個圓角矩形區域,然後再呼叫clip()方法,截掉圓角矩形區域外部分。有一點需要注意,clip()方法擷取的內容只對呼叫該方法後繪製的內容有效,呼叫該方法之前繪製的內容並不會被截掉。因此以下**必須放在繪製背景的**前。

// 繪製圓角矩形

, type : function(g, rect, comp, data, view)

}

看下效果如何

至此,進度條的設計就結束了,那麼接下來就來看下進度條如何與檔案上傳結合起來:

首先,我們需要有個伺服器來接收檔案,伺服器中除了使用常規的web伺服器外(web伺服器的簡單配置可參考:ht for web的html5樹元件延遲載入技術實現),還使用了formidable模組,以下是伺服器的**:

var express = require('express'),

io = require('socket.io')(server),

path = require('path'),

root = path.join(__dirname, '../../../'),

formidable = require('formidable');

// io監聽connection事件

io.on('connection', function(socket));

// 設定伺服器的工作路徑

var form = new formidable.incomingform();

form.on('end', function());

form.on('progress', function(bytesreceived, byte***pected));

form.parse(req);

});// 伺服器監聽4000埠

server.listen(3000, function());

其次,我們需要設計乙個檔案上傳的表單:

再者,我們需要結合ajax無重新整理向伺服器上傳檔案,並結合socket技術監聽伺服器事件,在瀏覽器如何使用socket可以參考:ht for web的html5樹元件延遲載入技術實現。

html5 進度條上傳檔案

error reporting e all header content text html charset utf 8 uf files filetoupload if uf upload file temp uf tmp name upload file name uf name if uplo...

移動端HTML5實現檔案上傳

pc端上傳檔案多半用外掛程式,引入flash都沒關係,但是移動端要是還用各種冗餘的外掛程式估計得被噴死,專案裡面需要做上傳的功能,既然h5已經有相關的介面且相容性良好,當然優先考慮用h5來實現。用的技術主要是 ajax filereader formdata html結構 div class cam...

HTML5 非同步上傳檔案

最近公司要做手機端 要用到上傳,手機端一般不能用 swfupload 類似flash的上傳工具 對 flash 支援不好 不過現在手機瀏覽器 都支援html5了 所以 這幾天網上查了下 實現使用html5 上傳檔案 其實 html5 上傳檔案挺簡單的 直接 new formdata 這個基於xmlh...