Blend UI 自定義事件 API

2018-10-17 11:34 更新
on ( event_type, callback ) 

自定義事件,為一個(gè)事件綁定回調(diào)函數(shù),同一事件可綁定多個(gè)回調(diào)函數(shù)。

Blend.ui.on(event_type,callback);
參數(shù)類型說(shuō)明是否必須
event_typeString事件名稱
callbackFunction事件綁定的回調(diào)函數(shù)fuction(event): event['detail']為layer的id, event['data']為通過(guò)fire方法傳遞過(guò)來(lái)的數(shù)據(jù)


可用的系統(tǒng)事件名稱

事件名稱說(shuō)明
layerCreateSuccesslayer創(chuàng)建成功
layerLoadFinishlayer頁(yè)面載入成功
layerPullDown下拉刷新loading
layerPopedlayer返回事件
tapslider點(diǎn)擊
slideslider滑動(dòng)切換
menuPressed菜單建事件
layerGoBacklayer中返回鍵goBack回調(diào)
backPressedBeforeExit返回鍵退出事件回調(diào)


實(shí)例

document.addEventListener("blendready",function() {
    var callbackA = function(e){
        console.log(e['data']);
    };
    var callbackB = function(e){
        console.log(e['detail']);
    };

    //注冊(cè)事件
    //如果是自定義的消息類型,則需要自行觸發(fā)
    Blend.ui.on("event",callbackA};
    Blend.ui.on("event",callbackB};

    Blend.ui.fire("event","false");

    //如果為系統(tǒng)事件,可以由系統(tǒng)觸發(fā)
    //如下為按下android返回鍵時(shí)的處理操作
    Blend.ui.on("backPressedBeforeExit",function(){
        console.log("back event");
    });
});


off ( event_type, [callback] )

解綁事件,解綁event_type類型的函數(shù)回調(diào)。

Blend.ui.on(event_type,[callback]);
參數(shù)類型說(shuō)明是否必須
event_typeString事件名稱
callbackFunction要解綁的函數(shù),如果callback為空或"all",將會(huì)刪除所有與event_type綁定的回調(diào)函數(shù)


實(shí)例

document.addEventListener("blendready",function(){
    var callbackA = function(e){console.log(e)};
    var callbackB = function(e){console.log(e)};
    Blend.ui.on("event",callbackA};
    Blend.ui.on("event",callbackB};
    //解綁callbackA
    Blend.ui.off("event",callbackA);
    //解除與event相關(guān)的所有綁定
    Blend.ui.off("event");
    //Blend.ui.off("event","all");
});


fire (event_type, targetId, message) 

觸發(fā)注冊(cè)的事件

Blend.ui.fire(type,targetId,message);
參數(shù)類型說(shuō)明是否必須
event_typeString事件名稱
targetIdString發(fā)送目標(biāo)的layerId, 如果是false則是廣播,如果為“0”則表示向首頁(yè)發(fā)送(通常為index.html)
messageObject/String發(fā)送的數(shù)據(jù)信息可以是字符串或者json數(shù)據(jù)


實(shí)例

document.addEventListener("blendready",function(){
    //自定義事件
    var callback = function(e){console.log(e)};
    Blend.ui.on("event",callback};

    Blend.ui.fire("event","0",{"url":"http://www.baidu.com"});
});


once ( event_type, callback ) 

注冊(cè)自定義事件,該自定義事件將在觸發(fā)后自動(dòng)注銷,只能執(zhí)行一次

Blend.ui.once(event_type, callback);
參數(shù)類型說(shuō)明是否必須
event_typeString事件名稱
callbackFunction事件綁定的回調(diào)函數(shù)fuction(event): event['detail']為layer的id, event['data']為通過(guò)fire方法傳遞過(guò)來(lái)的數(shù)據(jù)


實(shí)例

document.addEventListener("blendready",function() {
    var callback = function(e){console.log(e)};
    //注冊(cè)事件
    Blend.ui.once("event",callback};
    //觸發(fā)一次事件
    Blend.ui.fire("event","false");
    //二次觸發(fā)無(wú)效,事件已注銷
    //Blend.ui.fire("event","false");
});


layerInit ( layerId, callback )

在layerId對(duì)應(yīng)的頁(yè)面初始化后的執(zhí)行函數(shù)

Blend.ui.layerInit(layerId, callback);
參數(shù)類型說(shuō)明是否必須
layerIdStringlayer的id;當(dāng)layerId為"0"時(shí)表示首頁(yè)初始化后執(zhí)行callback函數(shù),其它頁(yè)面的id由用戶自行定義
callbackFunction在相應(yīng)layer初始化后執(zhí)行的函數(shù)


實(shí)例

document.addEventListener("blendready",function() {
    //定義頁(yè)面id為test的layer初始化后執(zhí)行的callback
    var callback = function(e){console.log("test layer ok")};
    Blend.ui.layerInit("test", callback);

    //創(chuàng)建layer并顯示
    var layer = new Blend.ui.Layer({
        "url":"content.html",
        "id":"test",
        "active":true
    });
});
以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)