ajax笔记2--操作表单 核心原生代码

news/2024/7/19 15:53:45 标签: ajax, js, php


ajax:asynchornous javascript and xml

异步的js和xml

ajax不是一种编程语言,是无需加载整个网页的情况之下能更新部分网页的技术


ajax主要使用到的是 XMLHttpRequest对象

通过XHR对象异步的与服务器交换数据

该对象有三个重要方法:

1.open(method,url,async)

method:表单提交方法,GET,POST

url:表单提交地址

async:是否同步,默认true,一般无需设置

2.setRequestHeader("content-type","application/x-www-form-urlencoded");

设置HTTP请求头

注意该方法必须写在send和open中间

3.send("name=王二狗&sex=男")

发送数据


服务器端使用php语言

php是创建动态交互性的站点的服务器端脚本语言

除此以外的服务器端语言还有,.net,java

php可以运行于各种服务器平台,兼容各种web服务器,支持几乎所有的数据库


WAMP:集成开发包

windows,Apache,Mysql,php



------------------------------------------------代码-----------------------------------------------


表单:

<span style="white-space:pre">	</span><h1>员工查询</h1>
	<label>输入编号</label>
	<input type="text" id="keyword"/>
	<br>
	<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>


服务器端:

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"] . " 信息保存成功!";
}



客户端:

<script>
document.getElementById("search").onclick = function() { 
	var request = new XMLHttpRequest();
	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();
	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>





http://www.niftyadmin.cn/n/705579.html

相关文章

linux 程序存储映像和执行映像

帧结构 一般情况下&#xff0c;一个可执行C程序在内存中主要包含5个区域&#xff0c;分别是代码段&#xff08;text&#xff09;&#xff0c;数据段&#xff08;data&#xff09;&#xff0c;BSS段&#xff0c;堆段&#xff08;heap&#xff09;和栈段&#xff08;stack&#x…

ajax笔记3--Jquery中的json

JSON&#xff1a;Javascript Object Notation 对象表示法 存储和交换文本信息的语法&#xff0c;类似于xml 采用键值对得方式组织 [ ]&#xff1a;表示数据 { } &#xff1a;表示一个数据 "name""depp" &#xff1a;一个键值对 JSONLint.com是一个在线…

Linux C获取磁盘空闲容量

struct statfs diskInfo; if(statfs("/opt", &diskInfo)-1) {exit(1); } unsigned long long availableDisk diskInfo.f_bavail * diskInfo.f_bsize; printf("磁盘可用空间 %lluMB\n",availableDisk>>20);

Linux C获取本机IP

方法1 #include <arpa/inet.h> #include <sys/socket.h> #include <netdb.h> #include <ifaddrs.h> #include <stdio.h> #include <stdlib.h> #include <unistd.h>int main(int argc, char *argv[]) {struct ifaddrs *ifaddr, *ifa…

ajax笔记4--如何解决跨域问题

一个完整的域名地址 http:// www. abc.com : 8080/ hello.html 协议 子域名 主域名 端口 请求资源地址 跨域就是 不同域之间相互请求资源 比如 http://www.abc.com/index.html 请求 http://www.efg.com/service.php javascript不允许跨域访问&#xff0…

Linux C获取CPU占用率

通过读取/proc/stat文件获取当前系统的CPU占用率。 Linux系统上的/proc目录是一种文件系统&#xff0c;即proc文件系统&#xff0c;与其它常见的文件系统不同的是&#xff0c;/proc文件系统是一个伪文件系统&#xff0c;它只存在内存当中&#xff0c;而不占用外存空间。它以文…

JDBC使用介绍

注意&#xff1a;连接之前先导入数据库Jar包&#xff01;&#xff01; JDBC使用步骤&#xff1a; 第一步&#xff0c;加载驱动程序 java加载驱动需要用到反射机制 Class.forName(driverClass) 加载Mysql驱动&#xff1a;Class.forName("com.mysql.jdbc.Driver"); …

Linux指定网卡名称

udev是Linux&#xff08;linux2.6内核之后&#xff09;默认的设备管理工具。udev 以守护进程的形式运行&#xff0c;通过侦听内核发出来的 uevent 来管理 /dev目录下的设备文件。 动态管理&#xff1a;当设备添加 / 删除时&#xff0c;udev 的守护进程侦听来自内核的 uevent&am…