1

使用 wicket-dnd,是否可以将dropTop()/dropBottom()与 HTML 表格一起使用?如果是这样,选择器应该是什么?

我有一个通过 a 创建的 HTML 表,ListView并且在 上取得了成功dropCentre("tr"),但这是唯一可行的删除选项。理想情况下,我想使用dropTopAndBottom()并查看表行之间的水平分隔线,它指示放置目标。

更新: 这是相关代码,为简洁起见进行了简化。有问题的表格每行都有一个标签,并被添加到表单中。

    // Container class for Wicket DND
    final WebMarkupContainer dataWrapper = new WebMarkupContainer("dataWrapper");
    dataWrapper.add(new WebTheme());

    final ListView<BinaryData> data = new ListView<BinaryData>("data", list) {

        @Override
        protected void populateItem(final ListItem<BinaryData> item) {
            final BinaryData data = item.getModelObject();
            item.add(new Label("label", data.getLabel()));
        }

        @Override
        protected ListItem<BinaryData> newItem(final int index, final IModel<BinaryData> itemModel) {
            final ListItem<BinaryData> item = super.newItem(index, itemModel);
            item.setOutputMarkupId(true);
            return item;
        }
    };

    dataWrapper.add(data);
    dataWrapper.add(new DragSource(Operation.MOVE) {

        @Override
        public void onAfterDrop(final AjaxRequestTarget target, final Transfer transfer) {
        }
    }.drag("tr"));

    dataWrapper.add(new DropTarget(Operation.MOVE) {

        @Override
        public void onDrop(final AjaxRequestTarget ajaxTarget, final Transfer transfer, final Location location) {

        }
    }.dropTopAndBottom("tr"));

    form.add(dataWrapper);

和标记:

<div wicket:id="dataWrapper">
    <table>
        <tbody>
            <tr wicket:id="data">
                <td wicket:id="label"></td>
            </tr>
        </tbody>
    </table>
</div>

我正在使用 Wicket-DND 0.6.0 和 Wicket 6.6.0。当我使用此代码拖动一行时,我会在拖动指示器中显示红十字图标。

4

2 回答 2

0

wicket-dnd 使用标准的 css 选择器来确定放置位置。

以下是 wicket-dnd-examples 中修改后的 TableExample:

table.add(new DropTarget(Operation.MOVE)
{
    @Override
    public void onDrop(AjaxRequestTarget target, Transfer transfer, Location location)
            throws Reject
        // something was dropped
    {
}.dropTopAndBottom("tr");
于 2013-07-28T14:55:25.400 回答
0

我的问题不是由 Wicket DND 引起的,而是由我的标记中对 JQuery UI 的明显冲突引用引起的(Wicket DND 不需要 JQuery UI,但在我的应用程序的其他组件中存在)。

将其替换为 WiQuery 提供的参考不再导致任何问题:

@Override
public void renderHead(final IHeaderResponse response) {
    super.renderHead(response);

    // Ensure that Wicket's jQuery library is always loaded, so we can invoke our own jQuery calls
    response.render(JavaScriptReferenceHeaderItem.forReference(getApplication().getJavaScriptLibrarySettings().getJQueryReference()));
    response.render(JavaScriptReferenceHeaderItem.forReference(CoreUIJavaScriptResourceReference.get()));
}
于 2013-08-07T02:33:12.943 回答