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:
将请求发送到服务器:
- open(发送请求方法[get/post],请求地址[相对/绝对],采用异步或同步,默认异步true[true/false]);
- send(string),get可以不填写,post必须填写。
- get
- post
- 取得响应
这里需要注意的是,status会用于后面传递数据时判断用,诸多原因会产生很多错误形式,比如0错误,200错误,500错误等等,后头会专门总结,今天天色已晚,我看大家还是早点洗洗睡吧。(我要睡觉!)。
readyState:
- readyState属性
- onreadyState事件监听readyState返回状态:
实例:
html&js:
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Demo1</title>
<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):
<?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.
“任何道德上的东西,也许都抵不住人性水滴石穿般的力量。”