今天,继续介绍我在尝试开发的Google Ajax Image Search控件。
为了允许用户保存自己选择的图片,Google Search API提供了一个Callback.因此,修改如下代码:
java 代码
- .append("function MyKeepHandler(result) {\n")
- .append("\twicketAjaxPost('" + getCallbackUrl() + "','url='+wicketEncode(result.url)+'&tbUrl='+wicketEncode(result.tbUrl));\n")
- .append("}")
在这段代码中,利用Behavior提供的Callback机制,把js中用户选择的图片的url上传到Behavior。
相应的相应代码如下:
java 代码
- @Override
- protected void respond(AjaxRequestTarget target) {
- RequestCycle requestCycle = RequestCycle.get();
- String tbUrl = requestCycle.getRequest().getParameter("tbUrl");
- String url = requestCycle.getRequest().getParameter("url");
-
- onSelect( url , tbUrl , target );
- }
- protected abstract void onSelect(String url , String tbUrl , AjaxRequestTarget target);
这里,我引入了一个虚函数,onSelect。通过实现这个函数,页面可以对选择的图片信息进行进一步的处理。在这里,我们先在页面中加入一个列表区域,显示用户选择的所有图片:
首先修改新的GImageSearch的创建代码。
java 代码
- add( new GImageSearch("gsearch",null) {
- @Override
- protected void onSelect(String url, String tbUrl, AjaxRequestTarget target) {
-
- images.add( url );
- imageList.modelChanged();
- target.addComponent( container );
- }
- });
引入了两个变量
java 代码
- private List<string> images = </string>new ArrayList<string>(); </string>
- private ListView imageList;
images保存历史图片。imageList则是一个用来显示list数据的wicket控件。
java 代码
- private WebMarkupContainer container;
-
- container = new WebMarkupContainer("savedList-panel");
- add( container );
- container.setOutputMarkupId(true);
- container.add( imageList = new ListView("savedImage", images) {
-
- @Override
- protected void populateItem(ListItem item) {
-
- item.add( new StaticImage("image", item.getModel()));
- }
-
- });
-
代码注释:
- 因为,当用户修改图片列表后,需要更新列表显示区域,这就是前面: target.add( container )的含义。通知wicket,本次ajax调用需要更新container对象。
- 对于需要ajax更新的对象,必须调用setOutputMarkupId(true)
- ListView是一个静态界面对象,重复Render的时候,不会再次访问它的model。因此,必须调用listview.modelChange()。也可以试用RefreshingView等动态repeater界面控件。不过代码会多些。
- 这里额外加入了一个container。开始的时候,我直接调用target.add( imageList ),但是得到一个错误提示,对于像listview这样的对象,只能更新他们的包含对象。因此,必须给他们一个通用的包含对象。
java 代码
- class StaticImage extends WebComponent {
-
- public StaticImage(String id, IModel model) {
- super(id, model);
- }
-
- protected void onComponentTag(ComponentTag tag) {
- checkComponentTag(tag, "img");
- tag.put("src", getModelObjectAsString());
- }
-
- }
wicket 却省的Image是使用Resource作为url来源。这里copy了一个例子。
http://cwiki.apache.org/WICKET/how-to-load-an-external-image.html
相应的HTML代码:
xml 代码
- <body>
- <span wicket:id="gsearch" />
- <div wicket:id="savedList-panel" >
- <ul><li wicket:id="savedImage">
- <img wicket:id="image" />
- <!---->li><!---->ul>
- <!---->div>
-
- <!---->body>
javaeye贴HTML代码有问题,一旦重复编辑就会乱掉!
现在可以看一下效果了。
分享到:
相关推荐
具体来说,第一个选择框包含三个选项:“1”、“2”、“3”,而第二个选择框中的选项则为第一个选择框选中项的十倍。 为了实现这一功能,我们需要重写第一个选择框的`onChange`方法,使得当第一个选择框的值发生...
Ajax-jaulp-wicket.zip,这个项目是ApacheWicket组件和实用程序的集合。,ajax代表异步javascript和xml。它是多种web技术的集合,包括html、css、json、xml和javascript。它用于创建动态网页,其中网页的小部分在不...
Wicket是一个灵活而强大的Java Web框架,它提供了一套简洁高效的API用于构建复杂的Web应用程序。与.NET平台的开发方式相似,Wicket允许开发者在HTML页面中声明控件,并在Java代码中处理这些控件的逻辑。本篇文章将...
#### 三、第一个例子 ##### 3.1 老姜一块--"Hello World" 在开始实际开发之前,先来实现一个经典的“Hello World”示例。这不仅可以帮助理解Wicket的基本用法,还可以确保开发环境已经正确设置。 ##### 3.2 ...
Wicket 是一个强大的Java Web应用程序框架,它提供了一种组件化的开发方式,使得开发者可以创建出高度交互且易于维护的Web应用。Wicket的基础控件是构建用户界面的核心元素,这些控件帮助开发者构建出丰富的表单、...
2. 第一个Wicket应用:介绍如何创建一个简单的"Hello, World!"应用,理解Wicket的基础架构。 3. 组件和页面:讲解Wicket中的组件模型,如何创建和使用组件,以及如何组织页面结构。 4. 模型和数据绑定:解释如何处理...
- **低学习曲线:** 相比其他框架,Wicket 提供了一个更直观的 API 和简洁的文档,使得新用户能够快速上手。 - **规则配置:** 减少了对 XML 配置文件的依赖,简化了开发流程。 - **Ajax 支持:** 内置了对 Ajax ...
1. **创建页面类**:在Wicket中,每个页面都有一个对应的Java类,类中定义了页面的组件和行为。 2. **绑定HTML模板**:页面类与HTML模板通过`@MountPath`注解或`WebPage`的构造函数关联。 3. **组件定义**:使用`add...
- **Wicket的历史与背景**:Wicket是一款基于Java的开源Web应用框架,它强调组件化的编程方式,并且支持多种现代Web开发特性,如AJAX等。Wicket的设计理念是为了简化Web应用的开发过程,使开发者能够更加专注于业务...
5. **开源生态**:Wicket社区活跃,有众多第三方组件和工具,如Eclipse插件WicketBench和Hibernate的数据绑定控件DataBinder,这些扩展丰富了Wicket的功能,提升了开发体验。 6. **Apache 孵化器项目**:Wicket从...
Wicket是一个流行的Java web应用程序框架,它提供了强大的组件模型和灵活的国际化支持。 **一、Wicket的国际化基础** 1. **什么是国际化(i18n)**:国际化是一种软件设计方法,使得应用程序能够适应不同地区的...
Wicket 是一个开源的Java Web框架,用于构建可重用且易于维护的Web应用程序。它以其组件模型和数据绑定机制而闻名,与Struts等传统MVC框架相比,提供了更直观和面向对象的编程方式。 在Wicket基础知识培训中,首先...
- **第1章:Wicket是什么**:介绍Wicket的历史背景、设计理念以及与其他框架的区别。 - **第2章:Wicket的架构**:深入探讨Wicket的内部架构,包括组件、模型和会话等核心概念。 - **第3章:构建一个简单的Wicket...
第一个例子 **3.1 老姜一块"HelloWorld"** 本节介绍了一个简单的Wicket "HelloWorld" 示例,展示了如何快速搭建一个Wicket项目。 **3.2 Wicket程序的开发步骤** - **3.2.1 制作一个Html模板** 创建HTML...
首先,我们看到一个名为"Wicket_tree2"的文件,这可能是源代码或者示例项目的第二部分,可能包含了对基础树结构的扩展或改进。在Wicket中,Tree通常由一系列TreeNode对象组成,每个TreeNode代表树中的一个节点,可以...
Apache Wicket 是一个开源的Java Web应用程序框架,它专注于提供简单、声明式、以及组件化的Web开发模型。在“apache-wicket-7”这个主题中,我们主要关注的是Wicket框架的第七个主要版本,即7.0.0-M3。这个版本是一...