Inter-Page Communication"
Line 1: | Line 1: | ||
{{ZKDevelopersReferencePageHeader}} | {{ZKDevelopersReferencePageHeader}} | ||
− | = | + | Communications among pages in the same desktop is straightforward. First, you can use attributes to share data. Second, you can use event to notify each other. |
+ | |||
+ | = Identify a Page= | ||
+ | |||
+ | To communicate among pages, we have to assign an identifier to the target page. In ZUML, it is done by use of [[ZUML Reference/ZUML/Processing Instructions/page|the page directive]]: | ||
+ | |||
+ | <source lang="xml"> | ||
+ | <?page id=" foo"?> | ||
+ | <window id="main"/> | ||
+ | </source> | ||
+ | |||
+ | Then we could retrieve it by use of <javadoc method="getPage(java.lang.String)" type="interface">org.zkoss.zk.ui.Desktop</javadoc> or by use of a utility class called <javadoc>org.zkoss.zk.ui.Path</javadoc>. For example, the following statements could access the ''main'' window above: | ||
+ | |||
+ | <source lang="java"> | ||
+ | comp.getDesktop().getPage("foo").getFellow("main"); | ||
+ | Path.getComponent("//foo/main"); | ||
+ | </source> | ||
− | + | As shown, <javadoc method="getComponent(java.lang.String)">org.zkoss.zk.ui.Path</javadoc> considers an ID starting with double slashes is a page. | |
− | = | + | = Use Attributes = |
Each component, page, desktop, session and Web application has an independent map of attributes. It is a good place to share data among components, pages, desktops and even sessions. | Each component, page, desktop, session and Web application has an independent map of attributes. It is a good place to share data among components, pages, desktops and even sessions. | ||
− | + | In Java , you could use "setAttribute()","removeAttribute()" and "getAttribute()" of <javadoc type="interface">org.zkoss.zk.ui.Component</javadoc>, <javadoc type="interface">org.zkoss.zk.ui.Page</javadoc> and so on to share data. Another way is using the scope argument to identify which scope you want to access. (In the following example, assuming comp is a component.) | |
− | |||
− | In Java , you could use "setAttribute()","removeAttribute()" and "getAttribute()" to share data. Another way is using the scope argument to identify which scope you want to access. (In the following example, assuming comp is a component.) | ||
<source lang="java" > | <source lang="java" > | ||
Line 18: | Line 32: | ||
</source> | </source> | ||
− | + | In <tt>zscript</tt> and EL expressions, you could use the [[ZUML Reference/EL Expressions/Implicit Objects|implicit objects]]: <tt>componentScope</tt>, <tt>pageScope</tt>, <tt>desktopScope</tt>, <tt>sessionScope, requestScope</tt> and <tt>applicationScope</tt>. | |
− | |||
<source lang="xml" > | <source lang="xml" > | ||
<window> | <window> | ||
− | + | <zscript><![CDATA[ | |
− | + | desktop.setAttribute("some","anyObject"); | |
− | + | desktopScope.get("some"); | |
− | + | ]]></zscript> | |
− | + | 1:${desktopScope["some"]} | |
</window> | </window> | ||
</source> | </source> | ||
− | |||
− | + | = Post and Send Events = | |
− | You could communicate among pages in the same desktop. The way to communicate is to use the < | + | You could communicate among pages in the same desktop. The way to communicate is to use the <javadoc method="postEvent(org.zkoss.zk.ui.event.Event)">org.zkoss.zk.ui.event.Events</javadoc> or <javadoc method="sendEvent(org.zkoss.zk.ui.event.Event)">org.zkoss.zk.ui.event.Events</javadoc> to notify a component in the target page. |
+ | For example, | ||
<source lang="java" > | <source lang="java" > | ||
Events.postEvent(new Event("SomethingHappens", | Events.postEvent(new Event("SomethingHappens", | ||
− | comp.getDesktop().getPage(" | + | comp.getDesktop().getPage("foo").getFellow("main")); |
</source> | </source> | ||
− | You can also pass object | + | You can also pass the data with the event object. The third parameter in <javadoc method="postEvent(org.zkoss.zk.ui.event.Event)">org.zkoss.zk.ui.event.Events</javadoc> will be put into <javadoc method="getData()">org.zkoss.zk.ui.event.Event</javadoc>. You could the data you want with it. |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
<source lang="java" > | <source lang="java" > | ||
− | + | Events.postEvent("onTest", target, "this will be send"); | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
</source> | </source> | ||
− | |||
− | |||
=Version History= | =Version History= | ||
{{LastUpdated}} | {{LastUpdated}} |
Revision as of 10:59, 25 November 2010
Communications among pages in the same desktop is straightforward. First, you can use attributes to share data. Second, you can use event to notify each other.
Identify a Page
To communicate among pages, we have to assign an identifier to the target page. In ZUML, it is done by use of the page directive:
<?page id=" foo"?>
<window id="main"/>
Then we could retrieve it by use of Desktop.getPage(String) or by use of a utility class called Path. For example, the following statements could access the main window above:
comp.getDesktop().getPage("foo").getFellow("main");
Path.getComponent("//foo/main");
As shown, Path.getComponent(String) considers an ID starting with double slashes is a page.
Use Attributes
Each component, page, desktop, session and Web application has an independent map of attributes. It is a good place to share data among components, pages, desktops and even sessions.
In Java , you could use "setAttribute()","removeAttribute()" and "getAttribute()" of Component, Page and so on to share data. Another way is using the scope argument to identify which scope you want to access. (In the following example, assuming comp is a component.)
comp.setAttribute("some","anyObject");
comp.getAttribute("some", comp.DESKTOP_SCOPE);
comp.getDesktop().getAttribute("some"); //is equivalent to previous line
In zscript and EL expressions, you could use the implicit objects: componentScope, pageScope, desktopScope, sessionScope, requestScope and applicationScope.
<window>
<zscript><![CDATA[
desktop.setAttribute("some","anyObject");
desktopScope.get("some");
]]></zscript>
1:${desktopScope["some"]}
</window>
Post and Send Events
You could communicate among pages in the same desktop. The way to communicate is to use the Events.postEvent(Event) or Events.sendEvent(Event) to notify a component in the target page.
For example,
Events.postEvent(new Event("SomethingHappens",
comp.getDesktop().getPage("foo").getFellow("main"));
You can also pass the data with the event object. The third parameter in Events.postEvent(Event) will be put into Event.getData(). You could the data you want with it.
Events.postEvent("onTest", target, "this will be send");
Version History
Version | Date | Content |
---|---|---|