关于hashchangebroker和statehashable的补充文档


Posted in Javascript onAugust 08, 2011

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]);
Javascript 相关文章推荐
JS刷新框架外页面七种实现代码
Feb 18 Javascript
使用ImageMagick进行图片缩放、合成与裁剪(js+python)
Sep 16 Javascript
JS面向对象编程详解
Mar 06 Javascript
利用AngularJs实现京东首页轮播图效果
Sep 08 Javascript
js调用屏幕宽度的简单方法
Nov 14 Javascript
javascript事件捕获机制【深入分析IE和DOM中的事件模型】
Dec 15 Javascript
Node.js中如何合并两个复杂对象详解
Dec 31 Javascript
前端编码规范(3)JavaScript 开发规范
Jan 21 Javascript
轻量级JS Cookie插件js-cookie的使用方法
Mar 22 Javascript
JS实现的RC4加密算法示例
Aug 16 Javascript
JavaScript 实现HTML DOM增删改查操作的常见方法详解
Jan 04 Javascript
Openlayers绘制地图标注
Sep 28 Javascript
基于jQuery的前端数据通用验证库
Aug 08 #Javascript
JS基础之undefined与null的区别分析
Aug 08 #Javascript
jQuery的12招常用技巧分享
Aug 08 #Javascript
利用javascript的面向对象的特性实现限制试用期
Aug 04 #Javascript
jquery动态加载图片数据练习代码
Aug 04 #Javascript
jquery里的正则表达式说明
Aug 03 #Javascript
基于jQuery的图片剪切插件
Aug 03 #Javascript
You might like
php使用cookie保存用户登录的用户名实例
2015/01/26 PHP
PHP封装的验证码工具类定义与用法示例
2018/08/22 PHP
JavaScript 利用StringBuffer类提升+=拼接字符串效率
2009/11/24 Javascript
JQuery对表单元素的基本操作使用总结
2014/07/18 Javascript
jquery实现鼠标滑过后动态图片提示效果实例
2015/08/10 Javascript
javascript实现简单加载随机色方块
2015/12/25 Javascript
前端JS面试中常见的算法问题总结
2016/12/23 Javascript
浅谈Vue数据响应
2018/11/05 Javascript
在vue项目中优雅的使用SVG的方法实例详解
2018/12/03 Javascript
vue+element项目中过滤输入框特殊字符小结
2019/08/07 Javascript
[51:26]VP vs VG 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
netbeans7安装python插件的方法图解
2013/12/24 Python
Python中断言Assertion的一些改进方案
2016/10/27 Python
Eclipse和PyDev搭建完美Python开发环境教程(Windows篇)
2016/11/16 Python
Python用UUID库生成唯一ID的方法示例
2016/12/15 Python
python3.6+django2.0开发一套学员管理系统
2018/03/03 Python
python实现傅里叶级数展开的实现
2018/07/21 Python
Python小游戏之300行代码实现俄罗斯方块
2019/01/04 Python
关于pytorch多GPU训练实例与性能对比分析
2019/08/19 Python
django使用F方法更新一个对象多个对象字段的实现
2020/03/28 Python
python 双循环遍历list 变量判断代码
2020/05/04 Python
python和php哪个更适合写爬虫
2020/06/22 Python
Under Armour美国官网:美国知名高端功能性运动品牌
2016/09/05 全球购物
法国床上用品商店:La Compagnie du lit
2019/12/26 全球购物
全球采购的街头服饰和帽子:Urban Excess
2020/10/28 全球购物
3个CCIE对一个工程师的面试题
2012/05/06 面试题
会计专业自我鉴定
2014/02/10 职场文书
酒店值班经理的工作职责范本
2014/02/18 职场文书
超市开学活动方案
2014/03/01 职场文书
大学生心理活动总结
2014/07/04 职场文书
2015年宣传思想工作总结
2015/05/22 职场文书
浅谈Python响应式类库RxPy
2021/06/14 Python
总结Java对象被序列化的两种方法
2021/06/30 Java/Android
「回转企鹅罐」10周年纪念展「輪るピングドラム展」海报公开
2022/03/22 日漫
Python字符串常规操作小结
2022/04/03 Python
Win11 KB5015814遇安装失败 影响开始菜单性能解决方法
2022/07/15 数码科技