JavaScript LaernNote之Ajax初体验

JavaScript Laern Note之Ajax初体验

大家好,我是Yangrl;
每天记录JavascriptLaernNote.
这几天在做一个在线报名系统,学生在线报名,分权限给学校后,学校们根据我们分配的账号登录后台查看各自学校的报名情况。表单部分用的盛行的Ajax表单提交。这个明后天我再发,今天先记笔记。O(∩_∩)O =>:).


Ajax初体验

Ajax是啥子?:全称:Asynchronous JavaScript and XML(异步的javascript和XML),它不是编程语言,是一种无需重新加载网页就能实现局部更新的技术。

但在学习Ajax之前还需要简单了解HTTP。

HTTP又是啥子?:HTTP(Hypertext transfer protocol) 超文本传输协议(无状态协议),每次都要重新传输,没有记忆。

HTTP请求:一般四个部分:
1.http请求的方法/动作,比如get/post.
2.URL(统一资源分配符)。
3.请求头,包含一些如客户端环境、身份验证信息。
4.请求体:请求正文,如含有提交的表单信息等。

HTTP响应:一般三个部分:
1.一个数字和文字组成的状态码,如:200 OK.
2.响应头,和请求头一样含信息,如服务器类型、时间、内容类型、长度等。
3.响应体:响应正文

请求方法
GET(一般查询, 获取):使用URL传参,发送数量2000字符串左右。
POST(一般新建/修改/删除):修改服务器上的资源,发送信息数量无限制。

常见状态码
1XX 信息类,表示接到浏览器(Browser)请求,正在处理。
2XX 成功,请求被正确接受,理解和处理。如:200 OK.
3XX 重定向,表示请求没有成功,用户必须进一步动作。
4XX 客户端错误,提交的请求没有成功。如:404 NOT Found(引用文档不存在)。
5XX 服务器错误,表示服务器不能完成对请求的处理。如:500.

[重点] XMLHttpRequest对象
example:
JavaScript LaernNote之Ajax初体验_第1张图片

将请求发送到服务器:

  • open(发送请求方法[get/post],请求地址[相对/绝对],采用异步或同步,默认异步true[true/false]);
  • send(string),get可以不填写,post必须填写。
  • get
    这里写图片描述
  • post
    这里写图片描述
  • 取得响应
    这里需要注意的是,status会用于后面传递数据时判断用,诸多原因会产生很多错误形式,比如0错误,200错误,500错误等等,后头会专门总结,今天天色已晚,我看大家还是早点洗洗睡吧。(我要睡觉!)。
    JavaScript LaernNote之Ajax初体验_第2张图片

readyState:

  • readyState属性

JavaScript LaernNote之Ajax初体验_第3张图片

  • onreadyState事件监听readyState返回状态:

JavaScript LaernNote之Ajax初体验_第4张图片

实例:
html&js:


<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Demo1title>
<style>
body, input, select, button, h1 {
    font-size: 28px;
    line-height:1.7;
}
style>    
head>

<body>

<h1>员工查询h1>

<label>请输入员工编号:label>
<input type="text" id="keyword" />
<button id="search">查询button>
<p id="searchResult">p>

<h1>员工新建h1>
<label>请输入员工姓名:label>
<input type="text" id="staffName" /><br>
<label>请输入员工编号:label>
<input type="text" id="staffNumber" /><br>
<label>请选择员工性别:label>
<select id="staffSex">
<option>option>
<option>option>
select><br>
<label>请输入员工职位:label>
<input type="text" id="staffJob" /><br>
<button id="save">保存button>
<p id="createResult">p>

<script>
document.getElementById("search").onclick = function() {
    var request;
    if(window.XMLHttpRequest) {
        request = new XMLHttpRequest;
    } else {
        request = new ActiveXObject('Microsoft.XMLHTTP');
    }
    //var request = new XMLHttpRequest();
    //var request = new ActiveXObject('Microsoft.XMLHTTP');

    request.open("GET", "server.php?number=" + document.getElementById("keyword").value);
    request.send();
    request.onreadystatechange = function() {
        if (request.readyState===4) {
            if (request.status===200) { 
                document.getElementById("searchResult").innerHTML = request.responseText;
            } else {
                alert("发生错误:" + request.status);
            }
        } 
    } 
}

document.getElementById("save").onclick = function() { 
    var request = new XMLHttpRequest();
    //var request = new ActiveXObject('Microsoft.XMLHTTP');
    request.open("POST", "server.php");
    var data = "name=" + document.getElementById("staffName").value 
                      + "&number=" + document.getElementById("staffNumber").value 
                      + "&sex=" + document.getElementById("staffSex").value 
                      + "&job=" + document.getElementById("staffJob").value;
    request.setRequestHeader("Content-type","application/x-www-form-urlencoded");
    request.send(data);
    request.onreadystatechange = function() {
        if (request.readyState===4) {
            if (request.status===200) { 
                document.getElementById("createResult").innerHTML = request.responseText;
            } else {
                alert("发生错误:" + request.status);
            }
        } 
    }
}
script>
body>
html>

php(server.php):


//设置页面内容是html编码格式是utf-8
header("Content-Type: text/plain;charset=utf-8"); 
//header("Content-Type: application/json;charset=utf-8"); 
//header("Content-Type: text/xml;charset=utf-8"); 
//header("Content-Type: text/html;charset=utf-8"); 
//header("Content-Type: application/javascript;charset=utf-8"); 

//定义一个多维数组,包含员工的信息,每条员工信息为一个数组
$staff = array
    (
        array("name" => "洪七", "number" => "101", "sex" => "男", "job" => "总经理"),
        array("name" => "郭靖", "number" => "102", "sex" => "男", "job" => "开发工程师"),
        array("name" => "黄蓉", "number" => "103", "sex" => "女", "job" => "产品经理")
    );

//判断如果是get请求,则进行搜索;如果是POST请求,则进行新建
//$_SERVER是一个超全局变量,在一个脚本的全部作用域中都可用,不用使用global关键字
//$_SERVER["REQUEST_METHOD"]返回访问页面使用的请求方法
if ($_SERVER["REQUEST_METHOD"] == "GET") {
    search();
} elseif ($_SERVER["REQUEST_METHOD"] == "POST"){
    create();
}

//通过员工编号搜索员工
function search(){
    //检查是否有员工编号的参数
    //isset检测变量是否设置;empty判断值为否为空
    //超全局变量 $_GET 和 $_POST 用于收集表单数据
    if (!isset($_GET["number"]) || empty($_GET["number"])) {
        echo "参数错误";
        return;
    }
    //函数之外声明的变量拥有 Global 作用域,只能在函数以外进行访问。
    //global 关键词用于访问函数内的全局变量
    global $staff;
    //获取number参数
    $number = $_GET["number"];
    $result = "没有找到员工。";

    //遍历$staff多维数组,查找key值为number的员工是否存在,如果存在,则修改返回结果
    foreach ($staff as $value) {
        if ($value["number"] == $number) {
            $result = "找到员工:员工编号:" . $value["number"] . ",员工姓名:" . $value["name"] . 
                              ",员工性别:" . $value["sex"] . ",员工职位:" . $value["job"];
            break;
        }
    }
    echo $result;
}

//创建员工
function create(){
    //判断信息是否填写完全
    if (!isset($_POST["name"]) || empty($_POST["name"])
        || !isset($_POST["number"]) || empty($_POST["number"])
        || !isset($_POST["sex"]) || empty($_POST["sex"])
        || !isset($_POST["job"]) || empty($_POST["job"])) {
        echo "参数错误,员工信息填写不全";
        return;
    }
    //TODO: 获取POST表单数据并保存到数据库

    //提示保存成功
    echo "员工:" . $_POST["name"] . " 信息保存成功!";
}

虎头蛇尾的结束,因为我需要睡觉了。Ajax主要还是和Json数据打交道,会继续更新Ajax.
Good night.
end.

“任何道德上的东西,也许都抵不住人性水滴石穿般的力量。”

你可能感兴趣的:(JavaScrip成长之路)