xpage全接触

上传人:第*** 文档编号:32819485 上传时间:2018-02-12 格式:DOCX 页数:15 大小:463.70KB
返回 下载 相关 举报
xpage全接触_第1页
第1页 / 共15页
xpage全接触_第2页
第2页 / 共15页
xpage全接触_第3页
第3页 / 共15页
xpage全接触_第4页
第4页 / 共15页
xpage全接触_第5页
第5页 / 共15页
点击查看更多>>
资源描述

《xpage全接触》由会员分享,可在线阅读,更多相关《xpage全接触(15页珍藏版)》请在金锄头文库上搜索。

1、developerWorks 中国 Lotus | Web development XPage 全接触级别: 初级刘 奇, 软件工程师, IBM2009 年 8 月 06 日XPages 是 IBM Lotus Notes/Domino 8.5 为 Lotus Domino Web 2.0 应用程序开发人员提供的新技术。本文将带领读者了解 XPage 的主要功能:XPage 基本控件、基本属性、对 Ajax 和 JavaScript 的支持、对控件的操作、XPage 事件模型等。XPage 全接触XPages 是 IBM Lotus Notes/Domino 8.5 为 Lotus Domin

2、o Web 2.0 应用程序开发人员提供的新技术。与以往发行版相比,它们提供了更大的灵活性,并且更好地控制交付给 Web 浏览器客户机屏幕的内容。本文将带大家全面了解 XPage 的各项功能, 图 1 显示了 Lotus Domino Designer 8.5 中 XPage 设计页面。在阅读本文的同时,建议读者阅读文章 在 Lotus Domino Designer 中利用 XPages 的威力,该文章是本文一个很好的补充。图 1. XPage 设计页面( 查看大图)基本控件和基本属性Lotus Domino Designer 提供了大量可重用的控件供用户开发 Web 2.0 的程序,它主要

3、分为两种:核心控件和容器控件。顾名思义,核心控件指一些比较基本的 XPage 控件,如编辑框、文本标签等;容器控件则是比较复杂、能够包含其它控件的控件,例如面板、表格、视图等。另外,用户还可以自己定制控件,以供自己或者别人重用。值得注意的是,通过拖拽控件面板上“Other”将控件放到 XPage 设计页面时,您会发现除了您在控件面板上看到的一些控件之外,“Other Controls”部分多了复选框组、单选按钮组等控件,如 图 2 所示。图 2. “Other Controls”回页首Lotus 软件试用下载立即下载最新版本的 IBM Lotus Notes 和 Domino 试用软件,尝试利

4、用 XPage 技术开发第一个 Domino Web 2.0 应用程序。 试用版下载: Lotus Domino 8.5 试用版下载: IBM Lotus Notes 8.5 和 Domino Designer 8.5 下面将分别阐述一下应用程序的属性、XPage 页面属性、控件基本属性以及自定义控件属性。应用程序属性点击 图 3 所示的 Application Properties 打开应用程序属性设置页面并点击 XPage Tab,如 图 4 所示。在这里,您可以设置数据验证代码是在服务器端还是在客户端执行,压缩以及编码格式和全球化相关的一些属性。图 3. “Application Pro

5、perties”入口图 4. 应用程序属性页面XPage 页面属性图 5 展示了 XPage 页面的属性。除了可以设置数据源、样式(字体及大小、背景色、边距等)之外,还可以添加 CSS 文件和 JavaScript 库。图 5. XPage 页面属性控件属性图 6 显示了 Edit 控件的基本属性,对于不同的控件,它的属性也有所不同。图 6. Edit 控件属性自定义控件属性自定义控件的属性除了具有 XPage 页面所具有的基本属性之外,它还允许用户添加新的属性,读者可以参考 “自定义控件与 compositeData”小节了解更多的内容。图 7. 自定义控件属性Ajax 和 JavaScri

6、pt 支持作为非常流行的交互式网页应用的网页开发技术 Ajax,其在 XPage 中得到了很好的支持。主要表现在以下几个地方:Ajax 部分页面刷新a. 适用任意的事件 对于任意事件,在服务器端允许用户选择页面更新的方式:全部更新、部分更新、不更新等。例如,点击“Refresh Panel”链接,将仅仅刷新“compute2”,其源码如 清单 1 所示。清单 1. 部分更新示例源码回页首 b. Pager 控件 XPages 中的 Pager 是用于数据源集合导航的控件,经常跟 View,Repeat,Data Table 等一起使用。如 图 8 所示,选中 Partial Refresh,该

7、 Pager 将仅仅刷新 viewPanel(刷新部分由 Attach to 指定的)的内容;反之,如果 Partial Refresh 没有被选中,则刷新整个页面中的内容。图 8. Pager 控件部分刷新Ajax TypeaheadTypeahead 是增强用户体验的一项重要措施,它能够根据用户输入的字符(串)猜测用户接下来可能输入的字符并帮助用户完成数据的输入。Edit 控件属性中有一项是 Type Ahead,如 图 9 所示,您可以在 Suggestions 中输入提示的字符串集,也可以书写 JavaScript 等返回字符串集合,其运行如 图 10 所示。图 9. Typeahea

8、d图 10. Typeahead 运行示例图嵌入 Dojo 作为客户端的代码库XPage 对 JavaScript 也有着非常好的支持。例如,不论是在客户端还是在服务器端,任意事件都支持 JavaScript。又例如,Computed Field 也支持 JavaScript 来计算这个域的值。在服务器端,XPage 还提供:1. 允许用户使用 function。 2. 大量的全局对象,例如 applicationScope,session 和 requestScope 等。 3. 大量的全局方法,例如 getComponent,getView,getClientId 等。 4. 允许用户使用

9、函数库 DOM、Domino、Runtime、Standard、XSP 等中的函数。 JavaScript 对控件的操作获取和设置 XPage 中控件的属性以及值在 XPage 应用程序开发过程中是非常重要的。下面将结合实例来讲述如何分别在客户端和服务器端上获取控件值或者属性:客户端创建一个简单的 XPage, 如 图 11 所示,源码如 清单 2 所示。图 11. XPage 示例清单 2. XPage 示例源码选择“设置编辑框文本”按钮并点击事件,书写事件“onClick”客户端运行的 JavaScript 脚本,如代码清单 3 所示。回页首清单 3. 客户端 JavaScript 代码(

10、操作控件的值)var editID = #javascript:getClientId(textExample); document.getElementById(editID).value = 您好!设置成功!; 其中,getClientId(textExample) 是用来获取编辑框的客户端 ID(如 view:_id1:textExample),但是仅仅服务器端可以使用这个函数。为了能够在客户端也能使用,需要将它放在 #javascript: . 中。当运行 XPage 时,这个嵌入在 #javascript: . 中的语句首先被执行,并将执行结果返回。点击“设置编辑框文本”按钮,编辑框

11、就会被设成“您好!设置成功!”。服务器端对上述例子,也可以书写服务器端脚本,如 清单 4 所示。清单 4. 服务器端 JavaScript 代码(操作控件的值)var editComponent:ponent.UIComponent = getComponent(textExample); editComponent.setValue( 您好!设置成功!); 其中,getComponent(textExample) 是用来获取 XPage 编辑框对象,调用 setValue 方法可以设置其值。细心的读者可能发现,除了 setValue 之外,还有很多 UIComponent editCompo

12、nent 方法供使用,例如 图 12 列出了一些设置编辑框属性的方法。图 12. UIComponent 设置方法列表回页首XPage 事件模型XPage 主要有以下几种事件:Page 事件如 图 13 所示,Page 事件主要有 beforePageLoad,afterPageLoad,afterRenderResponse ,afterRestoreView,beforeRenderResponse,beforeRestoreView 等。图 13. Page 事件Control 事件XPage 控件的事件比较多,如 图 14 所示,它分为鼠标、焦点、键盘三大类。读者可以参考 Lotus

13、Domino Designer 了解各个事件的具体含义。图 14. Control 事件Document 事件Document 事件主要包含 computeDocument,postNewDocument ,postOpenDocument ,postSaveDocument 等。View 事件View 事件包含 postOpenView,queryOpenView。ValidatorValidator 是用来验证 XPage 控件数据的合法性,它能够发生在服务器端,也可以发生在客户端,您有两种方法来设置这个属性:1. 在应用程序级别,可以打开“Application Properties X

14、Page TAB”来设置,如 图 15 所示。 图 15. 客户端数据验证设置(应用程序级别)2. 在控件级别,您可以在控件“Properties All Properties”中来设置,如 图 16 所示。 图 16. 客户端数据验证设置(控件级别)数据验证在客户端与服务器端执行返回结果的方式有所不同。仍以 图 11 所示例子来说明,我们对编辑框加上一个数据验证,如 图 17 所示,这样当点击按钮时就会提示“数据错误”的信息。图 17. 设置 Edit 控件数据验证属性假如在客户端执行数据验证,点击按钮就会弹出如图所示的对话框,如 图 18 所示。图 18. 数据错误警告框假如在服务器端执行

15、数据验证,我们需要创建一个“Display Error”控件来显示错误信息。Java 代码重用大家可能在想, 能不能重用 Java 代码,并在 JavaScript 中使用呢?答案是肯定的。主要分为以下几个步骤:1. 切换 Lotus Domino Designer 的视图至 Java 视图,如 图 19 所示。 回页首图 19. 切换视图2. 您可以选择在 Lotus Domino Designer 中创建一个项目,添加您要重用的 Java 代码,并将这个项目导出成一个 JAR 包。右击 项目,选择 “Export ”,并选择 Java - JAR file。注意:不是一定要求您在 Lotu

16、s Domino Designer 中创建项目,您也可以选择在其他地方,例如 Eclipse 中创建项目并导出来。 3. 将导出的 JAR 包放到 XPage 应用程序(NSF 文件)中。选择 WebContent WEB-INF,您应该能看到文件夹 lib (如果没有,请创建该文件夹),将 JAR 包放到 lib 文件夹下。这样,您就可以在此 XPage 应用程序中使用 JAR 包中所有的类和相应的方法了。 图 20. 添加 JAR 包4. 使用 JAR 中的类和方法。例如 清单 5 所示。 清单 5. XPage 中使用 Java 库示例var objectTest = new Test(); - Test 为 JAR 中包含的类。objectTest.print(); 值得注意的是

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 工程造价

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号