關(guān)于hashchangebroker和statehashable的補充文檔
url hash:url中#號后面那段,通常用來定位到html頁面中某一錨點。因為hash變化頁面不會刷新,所以在ajax應(yīng)用中用hash來存儲腳本運行狀態(tài),例如gmail的做法。
jquery hash change event plugin: Internet Explorer 8, Firefox 3.6+, 和Chrome 5+里,已經(jīng)提供了window.onhashchange事件,但是在老版本的瀏覽器中并沒有這個事件,這個插件通過定時器判斷hash是否產(chǎn)生了變化,以便在老版本的瀏覽器重提供hashchange事件。
hashchangebroker:之前寫了這個jquery extend,提供了四個方法:
$.hashchangebroker.subscrib(fragName, handler)
訂閱fragName對應(yīng)的hash段落變化,并轉(zhuǎn)發(fā)給指定的handler。
url hash由若干個frag組成,一個frag格式為:[fragName]:[state]。fragName為自定義hash狀態(tài)名稱。state為base64編碼的json字符串。
handler只有一個參數(shù)state:json格式字符串,描述自定義狀態(tài)。
$.hashchangebroker.publish(hash)
此方法應(yīng)綁定到window.onhashchange事件。接收hash并解碼找到變更的frag,并轉(zhuǎn)發(fā)給訂閱該frag的handler。
$.hashchangebroker.changeFrag(fragName,state)
此方法由statehashable類型調(diào)用,用于修改hash中對應(yīng)fragName的frag的state。
$.hashchangebroker.init()
此方法用于在頁面刷新后,獲取hash并publish。在$(document).ready中調(diào)用即可。應(yīng)放到所有subscrib方法之后。
statehashable:提供這個widget是希望可以比較方便的將控件的狀態(tài)發(fā)布到url hash,并獲取控件對應(yīng)的hash frag的state變化,觸發(fā)相應(yīng)的statechange事件。
用法$(dom).statehashable();調(diào)用此方法后,給dom對象增加了hashchange事件。當(dāng)statehashable對象發(fā)現(xiàn)控件對應(yīng)的hash frag變化后,會觸發(fā)dom對象的hashchange事件。
使用方法:
$(dom).bind("hashchange",function(e,stateObj){
//判斷stateObj的狀態(tài),還原dom到對應(yīng)的狀態(tài)
});
應(yīng)在更改dom狀態(tài)的方法中增加statechange的事件觸發(fā),statehashable對象會捕捉該事件,并調(diào)用hashchangebroker的changeFrag方法,修改hash。statechange觸發(fā)示例:
$(dom).trigger("statechange",[stateName,stateValue]);
相關(guān)文章
jQuery插件artDialog.js使用與關(guān)閉方法示例
這篇文章主要介紹了jQuery插件artDialog.js使用與關(guān)閉方法,結(jié)合具體實例形式分析了jQuery彈出窗口插件artDialog.js的簡單使用方法及相關(guān)注意事項,需要的朋友可以參考下2017-10-10Jquery實現(xiàn)textarea根據(jù)文本內(nèi)容自適應(yīng)高度
本文給大家分享的是Jquery實現(xiàn)textarea根據(jù)文本內(nèi)容自適應(yīng)高度,這些在平時的項目中挺實用的,所以抽空封裝了一個文本框根據(jù)輸入內(nèi)容自適應(yīng)高度的插件,這里推薦給小伙伴們。2015-04-04jQuery操作select下拉框的text值和value值的方法
這篇文章主要介紹了jQuery操作select下拉框的text值和value值的方法,需要的朋友可以參考下2014-05-05Zero Clipboard實現(xiàn)瀏覽器復(fù)制到剪貼板的方法(多個復(fù)制按鈕)
這篇文章主要介紹了Zero Clipboard實現(xiàn)瀏覽器復(fù)制到剪貼板的方法,帶有多個復(fù)制按鈕效果,涉及jQuery插件ZeroClipboard.js具體使用步驟與相關(guān)技巧,需要的朋友可以參考下2016-03-03jquery中常用的SET和GET$(”#msg”).html循環(huán)介紹
jquery中常用的SET和GET$(”#msg”).html循環(huán)想必大家并不陌生吧,本文整理了一些,感興趣的朋友可以參考下2013-10-10