Wicket + jsTree,链接生成在ajax响应中

时间:2010-08-31 10:51:14

标签: java ajax wicket jstree

我正在使用jsTree jQuery插件绘制树。 当用户单击某个节点时,会将包含节点ID的ajax请求发送到服务器。

在我的回复中,我生成了这样一段html(这是在单独的servlet中完成的):

<li id="node_id_1"><a href="foobar">Child item 1</a></li>
<li id="node_id_2"><a href="foobar">Child item 2</a></li>
<li id="node_id_3"><a href="foobar">Child item 3</a></li>
<li id="node_id_4"><a href="foobar">Child item 4</a></li>
<li id="node_id_5"><a href="foobar">Child item 5</a></li>

此项目在所选节点下绘制。

问题是:对于引用wicket页面的href属性,我应该使用什么值?即我需要使用一些参数指向类MainPage的链接。

1 个答案:

答案 0 :(得分:1)

您想要的是RepeatingViewListView,它会返回一些BookmarkablePageLink个对象:

这是一个示例组件:

public class JsTree extends Panel{

    private static final long serialVersionUID = 1L;

    public JsTree(final String id, final IModel<List<MyDomainObject>> model){
        super(id);
        this.add(new ListView<MyDomainObject>("list", model){

            private static final long serialVersionUID = 1L;

            @Override
            protected void populateItem(final ListItem<MyDomainObject> item){
                MyDomainObject modelObject = item.getModelObject();
                final Map<String, String> params =
                    Collections.singletonMap("id", modelObject
                        .getObjectId());
                item.add(
                    new BookmarkablePageLink<Void>(
                        "link", MyPage.class,
                        new PageParameters(params)
                    ).add(new Label("label",modelObject.getName()))
                ).setOutputMarkupId(true);

            }
        });
    }
}

和相应的HTML:

<html>
<body>
<wicket:head></wicket:head>
<wicket:panel>
    <ul class="jsTree">
        <li wicket:id="list">
            <a href="#" wicket:id="link">
                <wicket:container wicket:id="label" />
            </a>
        </li>
    </ul>
</wicket:panel>
</body>
</html>

我使用的MyDomainObject类型只有一个id和一个名字。显示名称,id链接到。基本上,您可以将任何可序列化参数添加到BookmarkablePageLink,然后使用Page.getPageParameters()方法解析您链接到的页面中的参数。