这次小编给大家整理了jQuery之AJAX的知识点,下面就是知识点汇总,一起来看一下。
一.AJAX概念
Asynchronous Javascript And XML(异步JavaScript和XML)
AJAX并不是一种语言,而是一种创建交互网页应用的网页开发技术
AJAX是Javascript、XHTML和CSS、DOM、XML和XSTL、XMLHttpRequest 等技术的组合
1.使用XHTML+CSS来标准化呈现;
2.使用XML和XSLT进行数据交换及相关操作;
3.使用XMLHttpRequest对象与Web服务器进行异步数据通信;
4.使用Javascript操作Document Object Model(网络文档对象模型)进行动态显示及交互;
5.使用JavaScript绑定和处理所有数据
什么是 XML?
XML 指可扩展标记语言(EXtensible Markup Language)
XML 是一种标记语言,很类似 HTML
XML 的设计宗旨是传输数据,而非显示数据
XML 标签没有被预定义。您需要自行定义标签。
XML 被设计为具有自我描述性。
XML 是 W3C 的推荐标准
什么是 XSLT?
XSLT 指 XSL 转换(XSL Transformations)[1]
XSLT 是 XSL 中最重要的部分
XSLT 可将一种 XML 文档转换为另外一种 XML 文档
XSLT 使用 XPath 在 XML 文档中进行导航
XSLT 是一个 W3C 标准
AJAX核心对象是XMLHttpRequest
二.AJAX工作原理
用户操作流程:
用户浏览器->JavaScript实例化XmlHttpRequest对象->AJAX引擎->http请求->web服务器->后台业务系统
系统返回流程:
后台业务系统->后台服务器->web服务器->HTML,XML,JSON数据->AJAX引擎->HTML+CSS(Wel浏览器)->用户浏览器
三.AJAX优缺点:
AJAX异步处理优点:
减轻服务器的负担,AJAX一般只从服务器获取只需要的数据
无刷新页面更新,减少用户等待的时间
更好的客户体验,可以将一些服务器的工作转移到客户端来完成,节约网络资源,提高用户体验
无平台限制
促进显示与数据想分离
AJAX异步处理的缺点:
页面中存在大量JS,给搜索引擎带来困难
AJAX干掉了Back和History功能,即对浏览器机制的破坏
存在跨域问题
只能传输及接收utf-8编码数据
1.AJAX实现步骤
window.open(URL,name,features,replace)
URL:一个可选的字符串,声明了要在新窗口中显示的文档的 URL。如果省略了这个参数
或者它的值是空字符串,那么新窗口就不会显示任何文档
name:一个可选的字符串,该字符串是一个由逗号分隔的特征列表,其中包括数字、字母和下划线,
该字符声明了新窗口的名称。这个名称可以用作标记 和
if (window.XMLHttpRequest) {// Mozilla, Safari, ...
var http_request = new XMLHttpRequest();
} else if (window.ActiveXObject) { // IE 5 ,6
var http_request = new ActiveXObject("Microsoft.XMLHTTP");
}XMLHttpRequest发出HTTP请求
http_request.open("GET|POST","test.php?GET方式传值",true);
http_request.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); //仅POST请求时需要设置
//用于向一个已经连接的socket发送数据
//如果是POST传输方式要把值写在send()函数里
http_request.send(向一个已连接的套接口发送数据);
XMLHttpRequest取得响应数据并显示
http_request.onreadystatechange=function(){
if(http_request.readyState==4 && http_request.status==200){
$("p").text(http_request.responseText)
}
}例:
//GET方式
参数1:代表是以get还是post方式发送请求 参数2:发送请求给哪个url 参数3:true代表异步请求,false代表同步请求
http_request.open("GET","test.php?user_name="+username.val(),true);
http_request.send();发送POST请求
var username=$("input[name='user_name']");参数1:代表是以get还是post方式发送请求 参数2:发送请求给哪个url 参数3:true代表异步请求,false代表同步请求
http_request.open("POST","test.php",true);
http_request.setRequestHeader("Content-Type","application/x-www-form-urlencoded");如果是POST传输方式要把值写在send()函数里
http_request.send({username:username});
四.JSON
Javascript Object Notation,是一种轻量级的数据交换格式
JSON每种语言都认识他所以用他进行各种语言的数据的转换
JSON支持多种语言
格式
{key:value,key:value,.....} 对象格式
[{key:value,key:value,.....},{key:value,key:value,.....},......] 数组格式
PHP处理:
$json=json_encode($array) //对变量进行Json编码
$array=json_decode($json) //对Json数据进行解码转换成PHP变量
JavaScript处理:
eval('('+json+')') //将某个字符串按照JS代码来执行
例:
eval("x=10;y=20;document.write(x*y)")
document.write(eval("2+2"))
JSON.parse(json) //对传过来的json字符串进行解码,变成JS认识的对象
JSON.stringify(obj) //将JS中的值编译成json字符串
五.jQuery中AJAX应用1
.不要忘写
$.ajax({
//你要传的php文件的路径
url:"test1.php", ('服务器url地址')
//以get方式传输拼接字符串
data:"user_name="+$('input[name="user_name"]').val(),('名=值&名=值&.....',)
//以什么方式传输
type:'get',('post|get')
//传输返回的数据类型
dataType:'json', ('xml|html|text|json|script')
//展示 数据的方式
success:function(res){
$('h1').text('用户名为:'+res.user_name);
},
//错误信息
error:function(xhr){
},
timeout:2000,
async:true,
cache:false
})六.jQuery中AJAX应用2
$.get()
$.get('服务器url地址',"json格式或字符串格式",function(res){
//处理返回的数据
}), "xml|html|json|text|script")例:
//'服务器url地址',"json格式或字符串格式"
$.get("test1.php",{user_name:$("input[name='user_name']").val()},function(data){
//如果后台发过来的值跟这里的值相等让他执行下面代码
if(data.status=='ok'){
alert("登陆成功");
location.href="http://www.wl.com";
}else{
alert("登陆失败");
}
//"xml|html|json|text|script"类型
},'json')
七.jQuery中AJAX应用3
serialize() 序列表表格内容为字符串,串行化数据 用于 Ajax 请求
$.post()
$.post('服务器url地址',"json格式或字符串格式",function(res){
//处理返回的数据
}), "xml|html|json|text|script")例:
//'服务器url地址',"json格式或字符串格式" 用post方式提交要用form表单包起来
// 然后用serialize()来拿里面所有有值
$.post("test1.php",$('form').serialize(),function(res){
//如果后台发过来的值跟这里的值相等让他执行下面代码
if(res.status=='ok'){
alert("登陆成功");
location.href="http://www.wl.com";
}else{
alert("登陆失败");
}
//"xml|html|json|text|script"类型
},'json')php中接收处理输出
try{
$pdo=new PDO("mysql:host=127.0.0.1;port=3306;dbname=数据库名",'数据库账号','数据库密码');
$pdo->exec("set names utf8");
$sen=$pdo->query("select * from yh_admin where user_name='{$user_name}' limit 1");
if($sen->rowCount()>0){
// $arr=$sen->fetch(PDO::FETCH_ASSOC);
//echo json_encode($arr);
//echo 'yes';
$arr['status']='ok';
}else{
echo 'no';
}
//切记用json数据类型传输
echo json_encode($arr);
}catch (PDOException $e){
echo $e->getMessage();
}以上就是jQuery之AJAX的知识点总结的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号