AJAX的一个简单实现

源码

 AJAX是前后端通讯的桥梁,后端可以获取前端提交的数据,处理后再返回给前端。这里为了演示简便,我们直接把从前端获取的值原样返回。本次使用php作为后台语言,php用法见这里

 先直接上代码:

 index.html为主页,index.js为它的js文件。php/main.php是后端php脚本。

index.html:

 1 <!DOCTYPE html>
 2 <html>
 3     <head>
 4         <title>Ajax Test</title>
 5         <link rel="stylesheet" href="index.css">
 6         <script type="text/javascript" src="index.js"></script>
 7     </head>
 8     <body>
 9         <div class="inputDiv">
10             <div class="label">INPUT:</div>
11             <input type="textfield" id="inputTextField"/>
12             <button onclick="outPut()">Output</button>
13         </div>
14         <div class="outputDiv">
15             <div class="label">OUTPUT:</div>
16             <div id="output">[Output at here]</div>
17         </div>
18     </body>
19 </html>

index.js

 

 1 function outPut()
 2 {
 3     inputStr = document.getElementById("inputTextField").value;//获取文本框的输入
 4     console.log(inputStr);//输出到控制台检查js获取是否正确
 5     xmlhttp = new XMLHttpRequest();//建立XMLHttpRequest对象
 6     
 7     xmlhttp.onreadystatechange = function()
 8     {
 9         if ((xmlhttp.readyState == 4) && (xmlhttp.status == 200))
10         {
11             document.getElementById("output").innerHTML = xmlhttp.responseText;//设置输出Div的innerHTML,设置为XMLHttpRequest对象返回的文本
12         }
13     }
14     
15     xmlhttp.open("GET","php/main.php?q=" + inputStr,true);
16     xmlhttp.send();
17 }

 

main.php

 要注意有的html页面中,由于要包含php代码,后缀名也会是php,需要跟后端的脚本php区分。这里我把脚本php文件放在了php目录下。

 

<?php
    //$q = isset($_GET["q"]) ? intval($_GET["q"]) : '';
    $q = $_GET["q"];
    echo $q;
?>

 

解析

 发送ajax时,首先要new一个XMLHttpRequest对象,使用它的open()方法与send()方法发送http请求。

  open():

  使用这个方法创建http请求,参数一共有五个,详见这里。文中的意思是使用GET请求,使用php下main.php脚本,url内嵌的q为文本框输入的内容,异步。

  send():

  发送请求。

 然后在后台脚本中,用$_GET获取url内嵌的q的值,然后就可以开始数据处理了。但是本次我们就直接echo回去。

 最后当onreadystatechange时,把html页面中输出div的innerHTML设为后台响应的数据。这里的responseText就是刚才php中echo的$q。

  readyState:

  当数据接收完毕时,readyState值为4。

  status:

  status是http状态码,200表示成功。

 

posted @ 2022-04-19 01:13  忠诚的女仆罗斯福  阅读(50)  评论(0编辑  收藏  举报