java - JSF 更新 primefaces 树子级

标签 java ajax jsf jsf-2 primefaces

我想更新 primefaces 树的子树,而不从服务器拉动整个树。

我可以更新整个树,但不能特定节点的子节点......

编辑:

这是我的代码示例:

<p:tree value="#{cc.tree}" var="wrapper" id="tree" widgetVar="tree" styleClass="commentTree-#{cc.id}">
   <p:treeNode id="treeNode" styleClass="treenode-#{wrapper.id}">
      Hallo: #{wrapper.text}
   </p:treeNode>
</p:tree>

现在我想更新特定的树节点。

function findIDbySelector(selector) {
    return $(selector).first().attr('id');
}

function updateComponent(clientID) {
    var ajax_json = {};
    ajax_json['source'] = '#{cc.id}';
    ajax_json['update'] = clientID;

    PrimeFaces.ajax.AjaxRequest(ajax_json);
}

[...]

updateComponent(findIDbySelector('.treenode-1'));

正如我所说,我可以更新整个树,但我只想更新单个 Treenode。

(代码可能包含错误/拼写错误,因为它被精简了)

最佳答案

我爬行了一些 primefaces 源代码,发现它们支持加载子项,这对我来说足够了(我可以将节点的内容包装到面板中并更新它和子项)。

为了更新子项,我修改了 primefaces Expandnode 方法:

function loadNodes(tree, c) {
    var a = tree;
    if (tree.cfg.dynamic) {
        if (tree.cfg.cache && c.children(".ui-treenode-children").children().length > 0) {
            tree.showNodeChildren(c);
            return
        }
        if (c.data("processing")) {
            PrimeFaces.debug("Node is already being expanded, ignoring expand event.");
            return
        }
        c.data("processing", true);
        var b = {
            source: tree.id,
            process: tree.id,
            update: tree.id,
            formId: tree.cfg.formId
        };
        b.onsuccess = function (j) {
            var g = $(j.documentElement),
                h = g.find("update");
            for (var e = 0; e < h.length; e++) {
                var l = h.eq(e),
                    k = l.attr("id"),
                    f = l.text();
                if (k == a.id) {
                    c.children(".ui-treenode-children").html(f);
                    a.showNodeChildren(c)
                } else {
                    PrimeFaces.ajax.AjaxUtils.updateElement.call(tree, k, f)
                }
            }
            PrimeFaces.ajax.AjaxUtils.handleResponse.call(tree, g);
            return true
        };
        b.oncomplete = function () {
            c.removeData("processing")
        };
        b.params = [{
            name: tree.id + "_expandNode",
            value: a.getRowKey(c)
        }];
        if (tree.hasBehavior("expand")) {
            var d = tree.cfg.behaviors.expand;
            d.call(tree, c, b)
        } else {
            PrimeFaces.ajax.AjaxRequest(b)
        }
    } else {
        tree.showNodeChildren(c);
        tree.fireExpandEvent(c)
    }
}

调用示例可以是:

loadNodes(tree, $('#j_idt62\\:tree\\:0'));

其中 tree 是 p:tree 的 WidgetVar

关于java - JSF 更新 primefaces 树子级,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13000870/

相关文章:

javascript - Jquery JSON .each() 在 Google Chrome 中不起作用

javascript - 如何将 Javascript 中的返回值传递给 Controller

java - Java EE Web 应用程序的架构

java - 从存储在 HashMap 中的字符串数组列表生成字符串组合

java - LibGDX - 对话框 - 如何删除标题栏?

java - 为什么我的数组程序显示为空?

java - 如何从 JSF 2.0 Facelets 模板调用 List.size()?

java - Hibernate @ManyToMany 映射给出异常

javascript - chrome 上的每个其他 ajax 请求都需要 10 倍的时间

java - 在 JSF/PrimeFaces 的数据表中显示包含 Date 对象的 HashMap 的内容