关于ZK框架的onScroll事件的问题
由于我现在所在的公司用到的zk框架,遇到了一个需求frozen on top。 简单来说就是滚动超过范围后,希望有一块东西停留在滚动窗口的顶部。
一.zk框架
查看了zk的8.x版本,发现组件的支持的事件(Event)最大的父类如下:
* <p>Events:<br/>
* onClick, onDoubleClick, onRightClick, onDrop,
* onMouseOver, onMouseOut, onOK, onCacnel, onCtrlKey and onSwipe.<br/>
*
abstract public class HtmlBasedComponent extends AbstractComponent {
...
static {
addClientEvent(HtmlBasedComponent.class, Events.ON_CLICK, 0);
addClientEvent(HtmlBasedComponent.class, Events.ON_DOUBLE_CLICK, 0);
addClientEvent(HtmlBasedComponent.class, Events.ON_RIGHT_CLICK, 0);
addClientEvent(HtmlBasedComponent.class, Events.ON_OK, 0);
addClientEvent(HtmlBasedComponent.class, Events.ON_CANCEL, 0);
addClientEvent(HtmlBasedComponent.class, Events.ON_CTRL_KEY, 0);
addClientEvent(HtmlBasedComponent.class, Events.ON_DROP, 0);
addClientEvent(HtmlBasedComponent.class, Events.ON_MOUSE_OVER, 0); //not to use CE_DUPLICATE_IGNORE since there is an order issue
addClientEvent(HtmlBasedComponent.class, Events.ON_MOUSE_OUT, 0);
addClientEvent(HtmlBasedComponent.class, Events.ON_SWIPE, CE_DUPLICATE_IGNORE);
addClientEvent(HtmlBasedComponent.class, Events.ON_AFTER_SIZE, CE_DUPLICATE_IGNORE);
}
...
}
发现最大的组件所支持的事件并没有我们想要的onScroll事件。然后查一下你想要滚动的目标组件,比如说div component:
div没有属于自己的事件注册。所以div所支持的事件都是父类的所注册的事件。
如果说我们想要在div监听到滚动事件呢?
二.创建属于自己系统的component
ZK框架的扩展性非常强。zk允许用户定义属于自己的组件,所以在这次解决问题的时候我创建了自己的组件cbxDiv。
我们需要做的有以下几点:
- 配置lang-addon.xml : 这是zk的配置文件,通常我们把所需要自己的组件信息都定义到这个配置文件,这样zk就会自动识别。
<?xml version="1.0" encoding="UTF-8"?>
<language-addon>
<addon-name>cul</addon-name>
<depends>zul,ckez</depends>
<language-name>xul/html</language-name>
....
<component>
<component-name>cbxdiv</component-name>
<component-class>com.core.cbx.ui.zk.cul.CbxDiv</component-class>
<widget-class>cul.wgt.CbxDiv</widget-class>
<extends>div</extends>
</component>
</language-addon>
这里的component-class就是你组件class的具体位置,widget-class是自己定义的js文件的所在位置。extend当然就是父类。
2.配置zk.wpd:这个是配置你组件的名字,以至于zk可以找到对应关系。
<?xml version="1.0" encoding="UTF-8"?> <package name="cul.wgt" language="xul/html" depends="zul.wgt">
<widget name="CbxDiv"/>
</package>
3.创建对应的component class
public class CbxDiv extends Div { static {
addClientEvent(CbxDiv.class, Events.ON_SCROLL, CE_IMPORTANT);
addClientEvent(CbxDiv.class, Events.ON_SCROLLING, CE_IMPORTANT);
} public CbxDiv() {
super();
} /*
* (non-Javadoc)
* @see org.zkoss.zk.ui.AbstractComponent#service(org.zkoss.zk.ui.event.Event, org.zkoss.zk.ui.ext.Scope)
*/
@Override
public void service(final AuRequest request, final boolean everError) {
final String cmd = request.getCommand();
if (Events.ON_SCROLL.equals(cmd)) {
final ScrollEvent evt = ScrollEventExt.getScrollEventExt(request);
Events.postEvent(evt);
} else if (Events.ON_SCROLLING.equals(cmd)) {
final ScrollEvent evt = ScrollEvent.getScrollEvent(request);
Events.postEvent(evt);
} else {
super.service(request, everError);
}
}
}
addClientEvent()这个方法是注册你自己想要的事件的。重写service是为了具体到的事件对应的处理类。并且数据的绑定。
注意:这个class创建的位置要跟lang-addon.xml配置的位置对应 4.创建自己的js
cul.wgt.CbxDiv = zk.$extends(zul.wgt.Div, { bind_: function() {
this.$supers(cul.wgt.CbxDiv, 'bind_', arguments);
this.domListen_(this.$n(), "onScroll", 'doScroll_');
}, unbind_: function() {
this.domUnlisten_(this.$n(), "onScroll", 'doScroll_');
this.$supers(cul.wgt.CbxDiv, 'unbind_', arguments);
}, doScroll_: function() {
this.fire('onScroll',{'x':this.$n().scrollLeft,'y':this.$n().scrollTop},{toServer:true});
} });
主要的方法是对我们的component绑定一个事件,然后触发这个事件的时候发送数据到后台。数据是以map的形式传送。
到这里基本上可以进行测试了。测试步骤就是创建一个cbxDiv,然后里面塞些东西。。在我们后台就可以动态的去加这个监听
test1Div.addEventListener(Events.ON_SCROLL, new EventListener<ScrollEventExt>() {
@Override
public void onEvent(final ScrollEventExt event) throws Exception {
system.out.print("scroll event have been fired!");
}
}
关于ZK框架的onScroll事件的问题的更多相关文章
- onscroll事件,onresize事件
js获取页面元素高度.宽度 网页可见区域宽: document.body.clientWidth; 网页可见区域高: document.body.clientHeight; 网页可见区域宽: do ...
- ZK框架的分析与应用
前言:本文是在下的在学习ZK官方文档时整理出来的初稿.本来里面有很多的效果图片和图片代码的.奈何博客园中图片不能粘贴上去,所以感兴趣的筒子们就将就吧.内容中,如有不好的地方,欢迎斧正! ZK框架的分析 ...
- ZK框架笔记1、ZK Ajax框架简介
简介 ZK是一个基于事件驱动和组件的框架,他为web应用提供了丰富的接口.zk包括一个基于Ajax的事件驱动引擎.一整套丰富的XML用户接口语言(XML User Interface Langu ...
- js动态添加onload、onresize、onscroll事件(另类方法)
js动态添加onload.onresize.onscroll事件(另类方法) window 的 onload.onresize.onscroll 事件,跟其他的事件不一样,它不能用 attachE ...
- zk框架中利用map类型传值来创建window,并且传值
@Command @NotifyChange("accList") public void clear(@BindingParam("id") String a ...
- 移动端(IOS)iframe监听不到 onscroll 事件
问题描述: 我在一个页面A中有瀑布流,点击瀑布流中的图片需要进入到另外一个页面B,点击返回需要回到页面A中点击的位置,为了实现该效果所以在页面A中嵌入iframe,iframe指向页面B,页面B中同样 ...
- onscroll事件没有响应的原因以及vue.js中添加onscroll事件监听的方法
1 onscroll事件失效 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...
- ZK框架笔记5、事件
事件是org.zkoss.zk.ui.event.Event类,它通知应用程序发生了什么事情.每一种类型的事件都由一个特定的类来表示. 要响应一个事件,应用程序必须为事 ...
- Minor【 PHP框架】5.事件
框架Github地址:github.com/Orlion/Minor (如果觉得还不错给个star哦(^-^)V) 框架作者: Orlion 知乎:https://www.zhihu.com/peop ...
随机推荐
- IPFS:Filecoin和复制证明
这篇文章主要来讲一下Filecoin协议里面的复制证明(Proof of Replication),由于协议涉及到很多概念,可能看起来有点晕乎乎的,小编尽量把复杂问题简单化 ,力求给大家做大普及IPF ...
- Hibernate 一对一关联映射,mappedBy参数解析
在最近java,SSH框架的学习中遇到了这样的一个问题,在Hibernate的开发中一对一关联映射的单向关联,主表会在次表新增一列次表的主键如下图,但是在双向关联中次表不会在表中创建主表的主键一列,这 ...
- MySQL——delete 和 truncate 以及 drop 区别
delete 和 truncate 以及 drop 区别 (个人理解,如有错误,请指出) delete < truncate < drop 删除方式: truncate 只删除数据.逐条 ...
- java编程基础知识及常见例题
⒈标识符: 只能包含数字.字母.下划线.$,并且不能以数字开头.语义直观规范 驼峰法则: 如:方法名.变量名采用驼峰法则 帕斯卡命名法: 如: 类.接口.枚举采用帕斯卡命名法包名:网址倒写,com.网 ...
- Markdown 语法手册 (完整整理版)
http://blog.csdn.net/witnessai1/article/details/52551362
- Shell 判断文件或文件夹是否存在
#shell判断文件夹是否存在 #如果文件夹不存在,创建文件夹 if [ ! -d "/myfolder" ]; then mkdir /myfolder fi #shell判断文 ...
- JVM学习五:JVM之类加载器之编译常量和主动使用
在学习了前面几节的内容后,相信大家已经对JAVA 虚拟机 加载类的过程有了一个认识和了解,那么本节,我们就继续进一步巩固前面所学知识和特殊点. 一.类的初始化回顾 类在初始化的时候,静态变量的声明语句 ...
- 网络通信 --> 同步、异步、阻塞与非阻塞介绍
同步.异步.阻塞与非阻塞介绍 聊聊同步.异步.阻塞与非阻塞
- Oracle的用户,权限以及角色
一.用户 1.创建用户 创建用户u密码为aa. SQL> create user u identified by aa; 2.为用户赋予权限 这个用户还不能连接数据库,必须为其赋予一些权限才可以 ...
- 如何解决js递归里面出现的堆栈溢出
16.下面的递归代码在数组列表偏大的情况下会导致堆栈溢出.在保留递归模式的基础上,你怎么解决这个问题? var list = readHugeList(); var nextListItem = fu ...