溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Preload基礎(chǔ)使用方法詳解

發(fā)布時(shí)間:2020-08-30 17:14:58 來源:腳本之家 閱讀:245 作者:AndyXB 欄目:web開發(fā)

PreloadJS是一個(gè)用來管理和協(xié)調(diào)相關(guān)資源加載的類庫,它可以方便的幫助你預(yù)先加載相關(guān)資源,例如

圖片,文件,音頻,數(shù)據(jù),其他

它使用了XHR2來提供實(shí)時(shí)的加載進(jìn)度信息,如果不支持則使用標(biāo)簽式的簡(jiǎn)化進(jìn)度來實(shí)現(xiàn)進(jìn)度展示。

支持多隊(duì)列,多連接,暫停隊(duì)列等等功能

在PreloadJS中,LoadQueue是主要用來預(yù)加載內(nèi)容的API。LoadQueue是一個(gè)加載管理器,可以預(yù)先加載一個(gè)文件或者一個(gè)文件隊(duì)列。

var queue = new createjs.LoadQueue(true);

以上代碼中,傳遞一個(gè)false參數(shù)則強(qiáng)制使用標(biāo)簽式的加載。LoadQueue包含了以下幾個(gè)可以訂閱的事件:

complete: 當(dāng)隊(duì)列完成全部加載后觸發(fā)

error: 當(dāng)隊(duì)列遇到錯(cuò)誤時(shí)觸發(fā)

progress: 整個(gè)隊(duì)列變化時(shí)展示的進(jìn)度

fileload: 一個(gè)單獨(dú)文件加載完畢

fileprogress: 一個(gè)單獨(dú)文件變化的進(jìn)度,請(qǐng)注意只有文件使用XHR加載才會(huì)觸發(fā),其它只會(huì)顯示0或者100%

可以通過調(diào)用loadfile("文件路徑")加載一個(gè)文件或者調(diào)用loadMnifest()來加載多個(gè)文件。

LoadQueue支持相關(guān)文件類型如下:

BINARY: XHR調(diào)用的二進(jìn)制文件

CSS: CSS文件

IMAGE: 一般圖片文件格式

JAVASCRIPT: JavaScript文件

JSON: JSON數(shù)據(jù)

JSONP: 跨域JSON文件

MANIFEST: JSON格式的文件列表

SOUND: 音頻文件

SVG: SVG文件

TEXT: 文本文件 - 僅支持XHR

XML: XML數(shù)據(jù)

代碼示例:

var canvas = document.getElementById("myCanvas");
var stage = new createjs.Stage(canvas);
var manifest;
var preload;
var progressText = new createjs.Text("", "20px Arial", "#dd4814");
progressText.x = 125 - progressText.getMeasuredWidth() / 2;
progressText.y = 20;
stage.addChild(progressText);
stage.update();
//定義相關(guān)JSON格式文件列表
function setupManifest() {
  manifest = [{
    src: "http://cdn.gbtags.com/EaselJS/0.7.1/easeljs.min.js", 
    id: "easeljs"
  }, {
    src: "https://cache.yisu.com/upload/information/20200622/114/7302.jpg",
    id: "logo"
  }, {
    src: "http://www.gbtags.com/tutorials/html5-tutorial/html5-demos/assets/song.ogg",
    id: "audiofile"
  }
 
  ];
  for(var i=1;i<=10;i++)
    manifest.push({src:"http://www.gbtags.com/gb/laitu/200x200"})
}
//開始預(yù)加載
function startPreload() {
  preload = new createjs.LoadQueue(true);
  //注意加載音頻文件需要調(diào)用如下代碼行
  preload.installPlugin(createjs.Sound);     
  preload.on("fileload", handleFileLoad);
  preload.on("progress", handleFileProgress);
  preload.on("complete", loadComplete);
  preload.on("error", loadError);
  preload.loadManifest(manifest);
 
}
//處理單個(gè)文件加載
function handleFileLoad(event) {
  console.log("文件類型: " + event.item.type);
  if(event.item.id == "logo"){
    console.log("logo圖片已成功加載");
  }
}
 
//處理加載錯(cuò)誤:大家可以修改成錯(cuò)誤的文件地址,可在控制臺(tái)看到此方法調(diào)用
function loadError(evt) {
  console.log("加載出錯(cuò)!",evt.text);
}
 
//已加載完畢進(jìn)度 
function handleFileProgress(event) {
  progressText.text = "已加載 " + (preload.progress*100|0) + " %";
  stage.update();
}
//全度資源加載完畢
function loadComplete(event) {
  console.log("已加載完畢全部資源");
}
setupManifest();
startPreload();

更多關(guān)于PreloadJS使用方法請(qǐng)點(diǎn)擊下面的相關(guān)鏈接

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI