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]);