0

こんにちは、これは議論されていることがわかりますが、問題/回答を熟読した後でも、この単純な AJAX 呼び出しでさえ準備完了状態 1 から抜け出すことができないようです。

私が持っているJavascriptは次のとおりです。

<script language="javascript" type="text/javascript">
var request;

function createRequest()
{
   try 
   {
      request = new XMLHttpRequest();
   }   catch (trymicrosoft) {
   try {
      request = new ActiveXObject("Msxml2.XMLHTTP");
   } catch (othermicrosoft) {
      try {
         request = new ActiveXObject("Microsoft.XMLHTTP");
         } catch (failed) {
           request = false;
         }
     }
 }
if (!request)
   alert("Error initializing XMLHttpRequest!");
}
function loadClassesBySchool()
{    
     //get require web form pieces for this call
 createRequest(); // function to get xmlhttp object
 var schoolId = getDDLSelectionValue("ddlSchools");   
 var grade = getDDLSelectionValue("ddlGrades");

     var url = "courses.php?grades=" + escape(grade) + "&schoolId=" + escape(schoolId);

 //open server connection
 request.open("GET", url, true);

 //Setup callback function for server response

   //+++read on overflow that some fixed the issue with an onload event this simply had
   //+++the handle spitback 2 readystate = 1 alerts

     request.onload = updateCourses();

     request.onreadystatechanged = updateCourses();

 //send the result
 request.send(); 
}

function updateCourses()
{

    alert('ready state changed' + request.readyState);

}

function getDDLSelectionValue(ddlID)
{
    return    document.getElementById(ddlID).options[document.getElementById(ddlID).selectedIndex].value;   
  }

</script>

PHP は、ブラウザー (IE/Chrome) で正常に読み込まれる単純な印刷物です。

<?php
    print "test";
?>

私はこれにかなり慣れていませんが、最も基本的なAJAX呼び出しを機能させることができないようです.これを過ぎてどのように作業するかについての助けは大歓迎です.

コールバック関数 'updateCourses' から得られるのは 1 だけです...

4

1 に答える 1

0

さらに掘り下げた後、私は実際にあきらめてjQueryに切り替えましたが、jQueryが機能するという事実を除いて、すべての意図と目的のためにまったく同じことを行う必要があります...私はそれに慣れていませんでしたが、そうです。

同じことを達成するためのjQueryは次のとおりです。

function loadCoursesBySchool(){

    var grades = getDDLSelectionValue("ddlGrades");
    var schoolId = getDDLSelectionValue("ddlSchools");

    jQuery.ajax({   
        url: "courses.php?grades=" + grades + "&schoolId=" + schoolId,  
        success: function (data) {  
            courseDisplay(data);    
        }   
    }); 
}

function courseDisplay(response)
{
    //check if anything was setn back!?
    if(!response)
    {
        $("#ddlCourses").html("");
        //do nothing?   
    }
    else
    {
        //empty DLL
        $("#ddlCourses").html("");
        //add entries
        $(response).appendTo("#ddlCourses");
    }       
}
于 2011-10-07T12:22:54.397 に答える