- 浏览: 1148145 次
- 性别:
- 来自: 火星郊区
博客专栏
-
OSGi
浏览量:0
文章分类
- 全部博客 (695)
- 项目管理 (48)
- OSGi (122)
- java (79)
- Vaadin (5)
- RAP (47)
- mysql (40)
- Maven (22)
- SVN (8)
- 孔雀鱼 (10)
- hibernate (9)
- spring (10)
- css (3)
- 年审 (6)
- ant (1)
- jdbc (3)
- FusionCharts (2)
- struts (4)
- 决策分析 (2)
- 生活 (10)
- 架构设计 (5)
- 破解 (2)
- 狼文化 (4)
- JVM (14)
- J2EE (1)
- 应用服务器 (1)
- 我的链接 (5)
- 数学 (2)
- 报表 (1)
- 百科 (6)
- Flex (7)
- log4j (2)
- PHP (1)
- 系统 (2)
- Web前端 (7)
- linux (6)
- Office (1)
- 安全管理 (5)
- python (2)
- dom4j (1)
- 工作流 (3)
- 养生保健 (4)
- Eclipse (8)
- 监控开发 (1)
- 设计 (3)
- CAS (1)
- ZK (41)
- BluePrint (3)
- 工具 (1)
- SWT (7)
- google (2)
- NIO (1)
- 企业文化 (2)
- Windoes (0)
- RCP (7)
- JavaScript (10)
- UML (1)
- 产品经理 (2)
- Velocity (10)
- C (1)
- 单元测试 (1)
- 设计模式 (2)
- 系统分析师 (2)
- 架构 (4)
- 面试 (2)
- 代码走查 (1)
- MongoDB (1)
- 企业流程优化 (1)
- 模式 (1)
- EJB (1)
- Jetty (1)
- Git (13)
- IPV6 (1)
- JQuery (8)
- SSH (1)
- mybatis (10)
- SiteMesh (2)
- JSTL (1)
- veloctiy (1)
- Spring MVC (1)
- struts2 (3)
- Servlet (1)
- 权限管理 (1)
- Java Mina (1)
- java 系统信息 (6)
- OSGi 基础 (3)
- html (1)
- spring--security (6)
- HTML5 (1)
- java爬虫搜索 (1)
- mvc (3)
最新评论
-
Tom.X:
http://osgia.com/
将web容器置于OSGi框架下进行web应用的开发 -
chenyuguxing:
你好, 为什么我的bundle export到felix工程中 ...
在Apache Felix中运行bundle -
string2020:
<niceManifest>true</ni ...
Bundle Plugin for Maven -
jsonmong:
OSGI,是未来的主流,目前已相当成熟。应用OSGI比较好的, ...
基于OSGi的声明式服务 -
zyhui98:
貌似是翻译过来的,有很少人在linux上做开发吧
如何成为“10倍效率”开发者
首先问题关键是,普通html页面与zul页面必须同域下,否则浏览器不允许跨域操作
思路:获取iframe 中zk页面中zk相关组件操作的js api,使用zk js api操作zk页面元素及激发事件
1,js关键代码
- function fireBtnEvent(){
- //获取iframe中的window对象
- var ifrmWindow =document.getElementById('ifrm').contentWindow;
- //获取zk页面中的jq对象,使用jq对象查找zk页面元素
- var jq =ifrmWindow.jq;
- //获取zk页面中js对象zk,用于dom到zk widget的转化与事件的构造
- var zk =ifrmWindow.zk;
- var btnLogin =zk.Widget.$(jq("$btnLogin"),ifrmWindow.document);
- ifrmWindow.zAu.send(new zk.Event(btnLogin,"onClick",null));
- }
function fireBtnEvent(){ //获取iframe中的window对象 var ifrmWindow =document.getElementById('ifrm').contentWindow; //获取zk页面中的jq对象,使用jq对象查找zk页面元素 var jq =ifrmWindow.jq; //获取zk页面中js对象zk,用于dom到zk widget的转化与事件的构造 var zk =ifrmWindow.zk; var btnLogin =zk.Widget.$(jq("$btnLogin"),ifrmWindow.document); ifrmWindow.zAu.send(new zk.Event(btnLogin,"onClick",null)); }
2,html页面完整代码
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <title> New Document </title>
- <meta name="Generator" content="EditPlus">
- <meta name="Author" content="">
- <meta name="Keywords" content="">
- <meta name="Description" content="">
- <script>
- function fireBtnEvent(){
- //获取iframe中的window对象
- var ifrmWindow =document.getElementById('ifrm').contentWindow;
- //获取zk页面中的jq对象,使用jq对象查找zk页面元素
- var jq =ifrmWindow.jq;
- //获取zk页面中js对象zk,用于dom到zk widget的转化与事件的构造
- var zk =ifrmWindow.zk;
- var btnLogin =zk.Widget.$(jq("$btnLogin"),ifrmWindow.document);
- ifrmWindow.zAu.send(new zk.Event(btnLogin,"onClick",null));
- }
- </script>
- </head>
- <body>
- <button id="demo" onclick="fireBtnEvent()">test</button>
- <iframe id="ifrm" height="500px" width="500px" src="login.zul" style="border:1px solid red;">
- </iframe>
- </body>
- </html>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <title> New Document </title> <meta name="Generator" content="EditPlus"> <meta name="Author" content=""> <meta name="Keywords" content=""> <meta name="Description" content=""> <script> function fireBtnEvent(){ //获取iframe中的window对象 var ifrmWindow =document.getElementById('ifrm').contentWindow; //获取zk页面中的jq对象,使用jq对象查找zk页面元素 var jq =ifrmWindow.jq; //获取zk页面中js对象zk,用于dom到zk widget的转化与事件的构造 var zk =ifrmWindow.zk; var btnLogin =zk.Widget.$(jq("$btnLogin"),ifrmWindow.document); ifrmWindow.zAu.send(new zk.Event(btnLogin,"onClick",null)); } </script> </head> <body> <button id="demo" onclick="fireBtnEvent()">test</button> <iframe id="ifrm" height="500px" width="500px" src="login.zul" style="border:1px solid red;"> </iframe> </body> </html>
3,zk页面完整代码
- <?xml version="1.0" encoding="utf-8"?>
- <?page cacheable="false" language="xul/html" zscriptLanguage="Java" contentType="text/html;charset=UTF-8"?>
- <?taglib uri="http://www.zkoss.org/dsp/web/core" prefix="c" ?>
- <?taglib uri="http://www.zkoss.org/zktools/zktools" prefix="z" ?>
- <div
- style="background: url('images/headerbg.png') repeat-x; background-position:0 -53px;height:100%;"
- xmlns:w="client" xmlns:n="native" xmlns="http://www.zkoss.org/2005/zul"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://www.zkoss.org/2005/zul http://www.zkoss.org/2005/zul/zul.xsd">
- <window apply="${z:ctrl('loginController')}" width="300px"
- height="140px" onOK="Events.postEvent("onClick",btnLogin,null);"
- mode="overlapped" position="center,top" style="margin-top:100px;">
- <caption>
- <div align="left" >
- <label value="欢迎您使用录音查询系统" style="font-weight:bold;font-size:14px;"></label>
- </div>
- </caption>
- <grid oddRowSclass="non-odd" height="115px">
- <columns>
- <column width="95px" align="right"></column>
- <column ></column>
- </columns>
- <rows>
- <row>
- <cell>用户名:</cell>
- <cell>
- <textbox id="txtUsername"></textbox>
- </cell>
- </row>
- <row>
- <cell>密码:</cell>
- <cell>
- <textbox id="txtPassword" type="password"></textbox>
- </cell>
- </row>
- <row height="50px">
- <cell colspan="2" align="center">
- <button label="登录" id="btnLogin" forward="onLogin" />
- </cell>
- </row>
- </rows>
- </grid>
- </window>
- </div>
<?xml version="1.0" encoding="utf-8"?> <?page cacheable="false" language="xul/html" zscriptLanguage="Java" contentType="text/html;charset=UTF-8"?> <?taglib uri="http://www.zkoss.org/dsp/web/core" prefix="c" ?> <?taglib uri="http://www.zkoss.org/zktools/zktools" prefix="z" ?> <div style="background: url('images/headerbg.png') repeat-x; background-position:0 -53px;height:100%;" xmlns:w="client" xmlns:n="native" xmlns="http://www.zkoss.org/2005/zul" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.zkoss.org/2005/zul http://www.zkoss.org/2005/zul/zul.xsd"> <window apply="${z:ctrl('loginController')}" width="300px" height="140px" onOK="Events.postEvent("onClick",btnLogin,null);" mode="overlapped" position="center,top" style="margin-top:100px;"> <caption> <div align="left" > <label value="欢迎您使用录音查询系统" style="font-weight:bold;font-size:14px;"></label> </div> </caption> <grid oddRowSclass="non-odd" height="115px"> <columns> <column width="95px" align="right"></column> <column ></column> </columns> <rows> <row> <cell>用户名:</cell> <cell> <textbox id="txtUsername"></textbox> </cell> </row> <row> <cell>密码:</cell> <cell> <textbox id="txtPassword" type="password"></textbox> </cell> </row> <row height="50px"> <cell colspan="2" align="center"> <button label="登录" id="btnLogin" forward="onLogin" /> </cell> </row> </rows> </grid> </window> </div>
4,其实更多操作widget对象的方法都类似,只要掌握1中的方法即可
发表评论
-
ZK PPT
2012-02-27 17:28 1199附件中为ZK系列的PPT -
zk+spring+hibernate延迟加载的解决办法
2012-02-24 14:22 1265由于Zk 的AU request,lazy load现在没 ... -
【zk开发】zk注解的秘密
2012-02-24 14:23 1586The DataBinder that reads ZUML ... -
【zk开发】zkstudio安装及使用视屏
2012-02-26 12:04 1238安装视屏 http://docs.zkoss.org/w ... -
zk主题生成器
2012-02-26 12:04 1614生成器在附件内,兼容zk3.x 与zk5.x,zktheme ... -
zk服务器端获取鼠标点击位置
2012-02-26 12:04 1390index.zul Xml代码 ... -
zk Fiddle-zk在线测试保存代码分享平台
2012-02-23 08:20 1465http://zkfiddle.org/ 是zk项目组之一 ... -
zksample2-一个复杂应用的zk示例
2012-02-23 08:19 1479Zks ample2 is a demo applica ... -
zk5.0.8发布
2012-02-23 08:18 953该版本是一个维护版本,主要于bug修复及引入几个新特性 ... -
zk数据绑定
2012-02-23 08:17 1792简介 : 关于数据绑 ... -
zk EE/PE/CE的区别
2012-02-18 09:32 3096自从zk5.0以后,zk拆分为 ... -
ZK 5.0.8 新特性
2012-02-18 09:32 18898月16日,zk官网:zk5.0.8将要发布 zk5. ... -
zk client与server code结合提高长操作的响应性
2012-02-18 09:32 1429一,关于长操作与响应性 zk client与serve ... -
zk tooltiptext中换行
2012-02-17 11:37 1534Xml代码 <window ti ... -
zk下载文件中文乱码解决方案
2012-02-17 11:37 3664本文来自http://sun4love.iteye.com/b ... -
【zk视频】如何了解一个组件默认支持服务器端事件
2012-02-17 11:37 1304如何了解一个组件默认支持服务器端事件? 知识点:在z ... -
【zk视频】如何查看zk源码,了解zk原理
2012-02-17 11:37 1646当org.zkoss.zul.Window关闭时,zk是如 ... -
ZK 5.0.7发布,及新特性
2012-02-15 09:10 1147ZK 是一套以 AJAX/XUL/Java 为基础的网页应用 ... -
use【组件公共属性】
2012-02-15 09:09 1084语法 apply="a-class- ... -
zk异步请求异常,自定义错误页面的bug
2012-02-15 09:09 1125zk版本5.0.6 现在遇到一个问题,觉得是bug, ...
相关推荐
在Vuex中,所有组件共享同一状态,并通过actions、mutations和getters来操作和获取数据。 二、组件事件回调 1. 自定义事件:如上所述,子组件可以通过`$emit`触发自定义事件,父组件通过`v-on`或简写`@`监听并处理...
标题 "拖拽一个iframe中的div 在另一个iframe页面中显示" 描述了在Web开发中一个交互性的技术,涉及跨框架(iframe)通信和DOM操作。这个技术主要应用于创建富交互的用户界面,允许用户在不同的iframe之间传递和操作...
在网页开发中,`iframe`(Inline Frame)是一种嵌入其他HTML文档的元素,它允许我们在一个页面中显示另一个页面的内容。本篇文章将深入探讨如何在`iframe`中调用JavaScript,实现父页面与子页面之间的方法交互。 一...
在ZK中,你可以在列表组件上设置一个事件监听器,当选择项改变时,将选中的ID通过事件发送出去,详情页面则订阅这个事件,接收到ID后加载对应的数据。 **ZK Example** 在压缩包"zkExample"中,可能包含了一个简单...
在网页开发中,有时我们需要实现一个功能,即在iframe中打开一个新的弹出窗口,并且这个弹出窗口能够遮罩住其父级页面,提供一种更好的用户体验。标题"iframe弹出框遮罩父类页面"正是关于这个技术点的讨论。在描述中...
在实际应用中,遮罩层通常与弹窗、模态框等组件配合使用,例如在`right.html`, `left.html`, `top.html`中的某个操作触发遮罩层显示,然后在完成特定任务后自动关闭。你可以通过修改JavaScript代码,添加相应的事件...
在网页开发中,`iframe`(Inline Frame)是一种嵌入其他HTML页面的元素,它允许我们在一个页面中显示另一个页面的内容。"iframe拖动功能"指的是实现`iframe`元素可以被用户通过鼠标拖动来改变其在页面中的位置。这种...
HTML5的跨iframe拖拽功能在移动端页面设计中是一个重要的技术点,它允许用户在不同的iframe之间自由地拖放元素,提升用户体验,特别是在构建可编辑的页面设计器时。本篇文章将详细探讨如何实现这一功能,并结合给定...
它通常用于警告用户他们正在进行的操作可能会导致数据丢失,但在这里我们可以利用它来监测`<iframe>`中页面的改变情况。 ##### 实现步骤: 1. **定义IFrame**: 在`main.html`中,通过`<iframe>`元素定义了一个...
通过创建一个iframe元素,并将其添加到文档中,可以实现在一个隔离的环境中进行打印,这样做的好处是用户可以打印页面的指定区域而不影响当前页面的其他内容。具体步骤如下: 1. 创建一个指定id的div元素作为打印...
在网页开发中,jQuery是一个非常流行的JavaScript库,它极大地简化了JavaScript的DOM操作,事件处理,动画设计以及Ajax交互。本篇文章将详细讲解如何利用jQuery实现iframe页面的切换功能,以便于创建更丰富的用户...
在网页开发中,有时我们需要在一个页面(子页面)中访问另一个页面(父页面)的数据或控制元素,这种情况下,`Iframe` 提供了一个解决方案。本文将深入探讨如何通过 `Iframe` 获取父页面的变量和控件。 首先,我们...
如果`iframe`加载的页面与主页面不在同一个域下,由于同源策略的限制,你可能无法直接在父页面中对`iframe`进行操作。此时,你需要在`iframe`内部的页面中处理右键菜单的禁用,或者使用`postMessage`和`message`事件...
标题“demo_DEMO_子页面刷新父页面iframe_”暗示我们关注的焦点是关于如何在子页面中触发父页面的刷新操作,特别是在一个IFrame上下文中。下面将详细探讨这个主题。 首先,我们需要了解IFrame(内联框架)的基本...
为了处理这种情况,通常我们会将相关操作放在iframe的“load”事件中或者在window的“load”事件中执行,以确保所有资源都已就绪。如果iframe内容动态加载,可能还需要考虑使用其他事件或定时器来检测DOM的变化。 ...
事件可以绑定在组件上,当达到触发事件,就会执行逻辑层中对应的事件处理函数。 事件对象可以携带额外信息,如 id, dataset, touches。 在组件中绑定一个事件处理函数。 如bindtap,当用户点击该组件的时候会在...
【标题】"zk组件封装demo"是一个示例项目,展示了如何对ZooKeeper(简称zk)组件进行封装,以便在实际开发中更高效、便捷地使用。ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,它是集群的管理者,...
在ZK中,所有的事件都被放入一个队列中等待处理。这样可以确保事件按照正确的顺序执行,并且避免了并发问题。 - **事件处理顺序**:事件按照它们被添加到队列中的顺序进行处理。 - **同步与异步处理**:可以根据...
Flex中的IFrame组件是一种在ActionScript(AS)环境中嵌入HTML内容或外部Web页面的工具。这个组件允许你在Flex应用程序中展示网页或者交互式的HTML内容,而无需直接修改HTML模板。这种功能对于需要在Flex应用中集成...
* 在该实例中,父组件中的按钮元素绑定了点击事件,并在事件处理函数中使用 `$refs` 对象来访问子组件的引用信息。 * 在子组件中,定义了一个 `parentMsg` 方法,并在父组件中被调用,用于接收父组件传递的参数。 ...