关于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 相关文章推荐
一个页面放2段图片滚动代码出现冲突的问题如何解决
Dec 21 Javascript
node.js中的socket.io入门实例
Apr 26 Javascript
不使用ajax实现无刷新提交表单
Dec 21 Javascript
浅谈Javascript 数组与字典
Jan 29 Javascript
理解jquery事件冒泡
Jan 03 Javascript
Vue.Js中的$watch()方法总结
Mar 23 Javascript
深入理解react-router@4.0 使用和源码解析
May 23 Javascript
javascript ES6 新增了let命令使用介绍
Jul 07 Javascript
jQuery中$原理实例分析
Aug 13 jQuery
js如何实现元素曝光上报
Aug 07 Javascript
Vue实现星级评价效果实例详解
Dec 30 Javascript
vue中音频wavesurfer.js的使用方法
Feb 20 Vue.js
基于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实现网站插件机制的方法
2009/11/10 PHP
php后台如何避免用户直接进入方法实例
2013/10/15 PHP
php中curl使用指南
2015/02/05 PHP
在jQuery中 常用的选择器介绍
2013/04/16 Javascript
你必须知道的JavaScript 中字符串连接的性能的一些问题
2013/05/07 Javascript
laytpl 精致巧妙的JavaScript模板引擎
2014/08/29 Javascript
js实现按钮加背景图片常用方法
2014/11/01 Javascript
基于ajax实现文件上传并显示进度条
2015/08/03 Javascript
jQuery xml字符串的解析、读取及查找方法
2016/03/01 Javascript
理解javascript对象继承
2016/04/17 Javascript
jQuery内容折叠效果插件用法实例分析(附demo源码)
2016/04/28 Javascript
Bootstrap中点击按钮后变灰并显示加载中实例代码
2016/09/23 Javascript
浅谈js继承的实现及公有、私有、静态方法的书写
2016/10/28 Javascript
浅谈Angular4中常用管道
2017/09/27 Javascript
微信小程序使用npm支持踩坑
2018/11/07 Javascript
vue-cli安装使用流程步骤详解
2018/11/08 Javascript
layui在form表单页面通过Validform加入简单验证的方法
2019/09/06 Javascript
python实现迭代法求方程组的根过程解析
2019/11/25 Javascript
[01:05:29]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Aster BO3 第二场 1月24日
2021/03/11 DOTA
python 实现归并排序算法
2012/06/05 Python
学习python之编写简单乘法口诀表实现代码
2016/02/27 Python
对pandas的dataframe绘图并保存的实现方法
2017/08/05 Python
Python异常处理操作实例详解
2018/05/10 Python
如何在Django中设置定时任务的方法示例
2019/01/18 Python
python程序 创建多线程过程详解
2019/09/23 Python
win10系统Anaconda和Pycharm的Tensorflow2.0之CPU和GPU版本安装教程
2019/12/03 Python
在django中自定义字段Field详解
2019/12/03 Python
使用Python实现Wake On Lan远程开机功能
2020/01/22 Python
美国最大婚纱连锁店运营商:David’s Bridal
2019/03/12 全球购物
介绍下Java的输入输出流
2014/01/22 面试题
销售业务实习自我鉴定
2013/09/23 职场文书
分厂厂长岗位职责
2013/12/29 职场文书
房屋租赁协议书范本
2014/04/10 职场文书
亮剑观后感
2015/06/05 职场文书
Java中的随机数Random
2022/03/17 Java/Android
vue实现拖拽交换位置
2022/04/07 Vue.js