ASP.Net TreeView Развернуть / Свернуть все не работает при наличии значков узлов

StackOverflow https://stackoverflow.com/questions/1639258

Вопрос

Я использовал следующий код js, чтобы развернуть / свернуть все узлы элемента управления ASP.Net TreeView:

// handle tree - this doesn't seem to work when the tree contains node images
function TreeviewExpandCollapseAll(treeViewId, expandAll) {
    var displayState = (expandAll == true ? "none" : "block");
    var treeView = document.getElementById(treeViewId);
    if (treeView) {
        var treeLinks = treeView.getElementsByTagName("a");
        var nodeCount = treeLinks.length;
        alert(nodeCount);

        for (i = 0; i < nodeCount; i++) {
            if (treeLinks[i].firstChild.tagName) {
                if (treeLinks[i].firstChild.tagName.toLowerCase() == "img") {
                    var currentToggleLink = treeLinks[i];
                    var childContainer = GetParentByTagName("table", currentToggleLink).nextSibling;
                    if (childContainer.style.display == displayState) {
                        eval(currentToggleLink.href);
                    }
                }
            }
        } //for loop ends
    }
}

//utility function to get the container of an element by tagname
function GetParentByTagName(parentTagName, childElementObj) {
    var parent = childElementObj.parentNode;
    while (parent.tagName.toLowerCase() != parentTagName.toLowerCase()) {
        parent = parent.parentNode;
    }
    return parent;
} 

Проблема заключается в том, что когда у меня NodeStyle-ImageUrl = " img / FolderSmall.gif " , расширение завершается неудачно после открытия первого дочернего узла - ТОЛЬКО при наличии изображений узлов.

Ошибка JS: childContainer - ноль:

                    if (childContainer.style.display == displayState) {
                        eval(currentToggleLink.href);

Я уверен, что кто-то еще сталкивался с этим, но весь код, который я нашел для развернуть / свернуть, терпит неудачу в тот же момент.

Это было полезно?

Решение

Это действительно давно, но если я правильно помню, я просто включил заполнитель изображения размером 1px, чтобы не возвращать ноль при любых вызовах.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top