Javascript - переменная теряет свое значение и становится неопределенной - PullRequest
6 голосов
/ 28 августа 2011

Кажется, я каким-то образом теряю значение переменной im setting ...

То, что я пытаюсь сделать, не так важно, поэтому я настроил ( Хорошо прокомментировано ) jsFiddle, чтобы показать вам, что я получаю.Также код приведен ниже.

Если кто-то может увидеть, что происходит, любая помощь приветствуется:)

См. JsFiddle> http://jsfiddle.net/qNWuV/4/ <Рекомендую посмотреть здесь</strong>

var habs = ["417,77", "410,363", "388,433", "262,435", "262,210", "391,101", "384,183", "61,114", "331,171", "164,433", "361,248", "302,329", "154,307", "410,350", "173,298", "308,429"]; //just an array of co-ords for another part of my app. Only the .length is used below.

//############################
// NOTE: as this problem depends on random numbers you MAY not see it. If "undefined" is ANYWHERE in the Result, the problem is occurring, otherwise re-run the code.
//############################


function link_habs(habs) {
    var test2 = '';
    var hab_length = habs.length;
    for (var e in habs) {
        var hab_link_1 = get_link(hab_length, e + ',');
        var hab_link_2 = get_link(hab_length, e + ',' + hab_link_1);
        document.write('<br /><br />each1: ' + hab_link_1); //Variable lost?
        document.write('<br />each2: ' + hab_link_2 + '<br />'); //Variable lost?
        test2 += e + ':' + hab_link_1 + ',' + hab_link_2 + '<br />';
    }
    document.write('<br /><br /><br />' + test2);
}

function get_link(count, not) {
    var nots = not.split(',');
    for (var i in nots) { nots[i] = parseInt(nots[i], 10); }
    var hab_link = Math.floor(Math.random() * count);
    if (nots.indexOf(hab_link) === -1) {
        document.write('<br />returned: ' + hab_link); //Variable is intact HERE
        return hab_link;
    } else {
        get_link(count, not);
    }
}

link_habs(habs);

Приветствия
Чарли

Ответы [ 2 ]

6 голосов
/ 28 августа 2011

Вы не возвращаете значение из рекурсивного вызова.

Изменение:

get_link(count, not);

в

return get_link(count, not);
1 голос
/ 28 августа 2011

В функции get_link вы пересекаете массив nots, используя for / in. Вы должны использовать обычный цикл for.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...