Показать сообщение отдельно
  #1 (permalink)  
Старый 24.08.2014, 14:15
Интересующийся
Отправить личное сообщение для frying Посмотреть профиль Найти все сообщения от frying
 
Регистрация: 11.02.2013
Сообщений: 12

js рекурсивная функция с for.. in циклом
В общем есть рекурсивная функция, ей передаётся объект и текстовый шаблон, функция должна вернуть свойства объекта и всех своих объектов если в их значении содержится текстовый шаблон.

<html>
<head>
    <meta charset="utf-8"> 
    <title>Test html with js tasks</title>
    <script type="text/javascript" src='./2.js'></script>
</head>
<body>
    <script type="text/javascript">
        var objSample = {
            "glossary": {
                "title": "example glossary",
                "GlossDiv": {
                    "title": "S",
                    "GlossList": {
                        "GlossEntry": {
                            "ID": "SGML",
                            "SortAs": "SGML",
                            "GlossTerm": "Standard Generalized Markup Language",
                            "Acronym": "SGML",
                            "Abbrev": "ISO 8879:1986",
                            "GlossDef": {
                                "para": "A meta-markup language, used to create markup languages such as DocBook.",
                                "GlossSeeAlso": ["GML", "XML"]
                            },
                            "GlossSee": "markup"
                        }
                    }
                }
            }
        };
        findProperty(objSample, 'SGML');
    </script>
    Pikabu
</body>
</html>


и сама функция:
function findProperty(obj, propContentPart) {
    for (var key in obj) {
        var value = obj[key];
        if (typeof value === 'object') {
            if (findProperty(value, propContentPart)) {
                console.log(key);
                return true;
            }
        } else {
            if (value.indexOf(propContentPart) > -1){
                console.log(key);
                return true;
            }
        }
    }
}


Получается следующий вывод:
ID
GlossEntry
GlossList
GlossDiv
glossary

Это цепочка(путь) до свойства, которое будет удовлетворять шаблону ( по-хорошему должно быть glossary->GlossDiv->GlossList->GlossEntry->Id). Проблема в том, что кроме него должны быть ещё свойства SortAs и Acronym со своими путями.

Похоже на то, что когда в стеке рекурсии появляется первый return, то по достижении изначального for in он сразу выходит из него. Понятно что он должен выходить из того уровня рекурсии, в котором он появился. Вопрос: почему он не продолжает идти по следующим свойствам?
Ответить с цитированием