1

私はxmlhttpオブジェクトにあまり精通しておらず、利用可能なドキュメントにもかかわらず、を取得するのに問題がありresponseTextます。とても近いですが、次のことがうまくいかない理由を指摘できる人なら誰でも感謝します。send()それがちょうど死んだ後...:

function fetchgenotype() {
    // here's where we use an Ajax function to fetch the allele values without reloading the page.
    // Get the index number of the genotype record to retrieve; retrieve it; populate the alleles.
    var mndx, sndx = 0;
    mndx = $('#marker').val();
    if (Study_selected) {
        sndx = $('#stylabid').val();
    } else {
        sndx = $('#pjtlabid').val();
    }
    if (window.XMLHttpRequest) {
        // code for IE7+, Firefox, Chrome, Opera, Safari
        xmlhttp = new XMLHttpRequest();
    } else {
        // code for IE6, IE5
        xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
    }
    xmlhttp.onreadystatechange = function () {
        if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
            // Recieve the return value, parse and assign to screen form. 
            var allele_stg = "";
            allele_stg = document.getElementById("allele_ary").innerHTML = xmlhttp.responseText;
            ary = new Array();
            ary = str_getcsv(allele_ary, ',');
            $('#allele_1_1').val() = ary[0];
            $('#allele_1_2').val() = ary[1];
        }
    }
    xmlhttp.open("GET", "fetchAlleles.php?mndx=" + mndx + "&sndx=" + sndx, true);
    xmlhttp.send();
} // end of fetchgenotype
4

1 に答える 1

1

ifステートメントを次のように変更すると、実際に得られる結果を確認できます。

if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
    // Receive the return value, parse and assign to screen form. 
    var allele_stg = "",
        rText = xmlhttp.responseText;
    /*
     * By assigning xmlhttp.responseText to a seperate variable
     * you can now check to make sure rText contains what you
     * expect to see.
     * 
     * By making the call to getElementById and assigning the
     * innerHTML property in separate statements, you can now
     * check to make sure that getElementById is returning a
     * DOM element, or if it's undefined.
     */
    allele_stg = document.getElementById("allele_ary");
    allele_stg.innerHTML = rText;
    ary = new Array();
    ary = str_getcsv(allele_ary, ',');
    $('#allele_1_1').val() = ary[0];
    $('#allele_1_2').val() = ary[1];
} else {
    console.log('xmlhttp.readyState:' + xmlhttp.readyState);
    console.log('xmlhttp.status:' + xmlhttp.status);
}

次に、コンソールを監視します。を取得していないか、取得していない可能200 xmlhttp.statusxmlhttp.readyStateがあり4ます。

于 2012-10-09T23:35:39.073 に答える