DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> jQuery入門知識 >> JQuery特效代碼 >> 關於hashchangebroker和statehashable的補充文檔
關於hashchangebroker和statehashable的補充文檔
編輯:JQuery特效代碼     

url hash:url中#號後面那段,通常用來定位到html頁面中某一錨點。因為hash變化頁面不會刷新,所以在ajax應用中用hash來存儲腳本運行狀態,例如gmail的做法。

jquery hash change event plugin: Internet Explorer 8, Firefox 3.6+, 和Chrome 5+裡,已經提供了window.onhashchange事件,但是在老版本的浏覽器中並沒有這個事件,這個插件通過定時器判斷hash是否產生了變化,以便在老版本的浏覽器重提供hashchange事件。

hashchangebroker:之前寫了這個jquery extend,提供了四個方法:

$.hashchangebroker.subscrib(fragName, handler)

  訂閱fragName對應的hash段落變化,並轉發給指定的handler。
  url hash由若干個frag組成,一個frag格式為:[fragName]:[state]。fragName為自定義hash狀態名稱。state為base64編碼的json字符串。
  handler只有一個參數state:json格式字符串,描述自定義狀態。

$.hashchangebroker.publish(hash)

  此方法應綁定到window.onhashchange事件。接收hash並解碼找到變更的frag,並轉發給訂閱該frag的handler。

$.hashchangebroker.changeFrag(fragName,state)

  此方法由statehashable類型調用,用於修改hash中對應fragName的frag的state。

$.hashchangebroker.init()

  此方法用於在頁面刷新後,獲取hash並publish。在$(document).ready中調用即可。應放到所有subscrib方法之後。

statehashable:提供這個widget是希望可以比較方便的將控件的狀態發布到url hash,並獲取控件對應的hash frag的state變化,觸發相應的statechange事件。

用法$(dom).statehashable();調用此方法後,給dom對象增加了hashchange事件。當statehashable對象發現控件對應的hash frag變化後,會觸發dom對象的hashchange事件。
使用方法:
代碼如下:
$(dom).bind("hashchange",function(e,stateObj){
//判斷stateObj的狀態,還原dom到對應的狀態
});

應在更改dom狀態的方法中增加statechange的事件觸發,statehashable對象會捕捉該事件,並調用hashchangebroker的changeFrag方法,修改hash。statechange觸發示例:
$(dom).trigger("statechange",[stateName,stateValue]);

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved