我正在处理应该通过AJAX与服务器交互的页面,但我对AJAX的使用经验非常有限。这是网页应该如何工作。使用AJAX发送和接收来自服务器的信息
单击按钮时,如果单击“测试”单选按钮,只需显示一个弹出窗口,说明输入有效。 单击按钮时,如果单击“实时”单选按钮,程序应该使用URL“http://cs.sfasu.edu/rball/351/exam2.php”向服务器发送一个请求,输入框的内容为“name”参数的值。 该页面将发回一个JSON对象,我需要将其解析为一个常规变量。
因为那不是我问的,我只剩下JSON的其余部分。
到目前为止,我已完成页面的设计,但就像我说过的,我并不真正知道我在做什么与AJAX的东西。我为它编写了一些代码,但不确定它是否正确。
这里是我的代码:
<html>
<head>
<title>anner, Taylor</title>
<style type = "text/css">
canvas {
border: 2px solid black;
}
</style>
<script type = "text/javascript">
window.onload = function() {
var TTcanvas = document.getElementById("myCanvas");
var TTcontext = TTcanvas.getContext("2d");
TTcontext.strokeStyle = "red";
TTcontext.fillStyle = "red";
TTcontext.fillRect(250,50,100,100);
TTcontext.stroke();
TTcontext.beginPath();
TTcontext.moveTo(600, 0);
TTcontext.lineTo(0, 200);
TTcontext.lineWidth = 5;
TTcontext.strokeStyle = "black";
TTcontext.stroke();
}
function validate() {
var TTinput = document.getElementById("3letters").value;
if(TTinput.length < 3 || TTinput.length > 3) {
alert("Please enter 3 letters");
}
var TTtest = document.getElementById("test");
var TTlive = document.getElementById("live");
if(TTtest.checked == true) {
alert("Input is valid");
}
else if(TTlive.checked == true) {
return ajaxStuff();
}
}
function ajaxStuff() {
var TTrequest = new XMLHttpRequest();
TTrequest.open("GET", "http://cs.sfasu.edu/rball/351/exam2.php?name=TTinput.value", true);
TTrequest.send();
var TTresponse = TTrequest.responseText;
TTrequest.onreadystatechange=function() {
if(TTrequest.readyState==4 && TTrequest.status==200) {
document.getElementById("myDiv").innerHTML.TTresponse;
}
}
}
</script>
</head>
<body>
<h1>Tanner, Taylor</h1>
<canvas id = "myCanvas" width = "600" height = "200"></canvas> <br>
<form>
Enter 3 letters: <input type="text" id="3letters"> <br>
<input type = "radio" id = "test" value = "test">Test
<input type = "radio" id = "live" value = "live">Live <br>
<input type = "button" id = "check" value = "Send" onclick="validate()">
</form>
<div id="myDiv">
</div>
</body>
</html>
这里是我的网页链接我们的服务器上:
cs.sfasu.edu/cs351121/exam2.html
另外,我知道它说的考试,但其实这只是一个回顾我们获得了下周的实际考试。我只是想弄清楚这是如何工作的,但不知道我做错了什么。
您的呼叫,导致给它一个无限循环的。开两次。 – TheProvost 2014-10-31 02:55:52
刚刚注意到,即将修改的帖子现在已经更正了代码。不再发生错误,但没有得到任何东西。 – 2014-10-31 03:03:59