AJAX

什么是AJAX

  1. AJAX= Asynchronous JavaScript and XML(异步的 JavaScript 和 XML);
  2. AJAX 不是新的编程语言,而是一种使用现有标准的新方法;
  3. 通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。

AJAX传输数据

$res = $conn->query($sql);
while($row = mysqli_fetch_assoc($res)) {
$arr[] = $row;
}
echo json_encode($arr);//返回的是json类型的字符串
// 返回到前端json,将数据转化为json对象发送到前台页面

AJAX如何使用

创建XMLHttpReauest对象

XMLHttoRequest是AJAX的基础。

var xhr;
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xhr=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xhr=new ActiveXObject("Microsoft.XMLHTTP");
}
// 选择一般只使用 xhr=new XMLHttpRequest();

xhr(XMLHttpRequest )的open方法

作用:创建一个新的http请求,并指定此请求的方法,URL以及验证信息(比如:用户名、密码);

语法:xhr.open("get/post","test.txt",true); // 调用了open方法仅仅是设置好参数而已

  1. 第一个参数是请求方式,一般使用get与post方法,与form标签的method类似;

    如果要使用post,需要添加请求头文件:

    xhr.setRequestHeader("Content-type","application/x-www-form-urlencoded;charset=UTF-8");
  2. 第二个参数是请求的URL;

    demo1:    xhr.open("get","getData.php",true)
    demo2: xhr.open("get","getData.php?key=a",true)
    demo3: xhr.open("get","getData.php?user=mike&pw=123",true)
    demo3: xhr.open("post","getData.php",true)
  3. 第三个参数是请求是同步还是异步进行,true表示异步。

xhr(XMLHttpRequest )的send方法

作用:调用了send方法后才会发出请求;

语法:xhr.send(data);

demo: xhr.send(“user=”+username+”&pw=”+pw); //以post方式传递时

//get方式发送请求时: xhr.send(null);

XMLHttpRequest 对象的三个重要的属性

属性 描述
onreadystatechange(事件属性) 存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数。
readyState属性 存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。 0: 请求未初始化. (还没有调用 open 方法) 1: 服务器连接已建立 (open 方法已被调用,) 2: 请求已接收 (send 已被调用。请求已经开始) 3: 交互中 ( 服务器正在发送响应) 4: 请求已完成,且响应已就绪 (响应发送完毕)
status属性 200: "OK" 404: 未找到页面

xhrr(XMLHttpRequest )的responseText 属性

(1)获取服务器响应数据;

(2)responseText 属性返回字符串形式的响应。

创建回调函数

(1)当请求被发送到服务器时,我们需要执行一些基于响应的任务;

(2)readyState 属性存有 XMLHttpRequest 的状态信息, 每当 readyState 改变时,就会触发 onreadystatechange 事件。当 readyState 等于 4 且状态为 200 时,表示响应已就绪;

(3) 在 onreadystatechange 事件中,我们规定当服务器响应已做好被处理的准备时所执行的任务。

xhr.onreadystatechange=function(){
if (xhr.readyState==4 && xhr.status==200)
{
//接收服务器端响应数据,并用js进行处理,显示在客户端页面
例:document.getElementById("myDiv").innerHTML=xhr.responseText;
}
}

xhr.abort()方法:停止当前请求

实际运用

js中

		btn.onclick = function() {
var xhr = new XMLHttpRequest();
xhr.open("get", "ajax.php", true);
xhr.send();
xhr.onreadystatechange = function () {
if (xhr.readyState == 4 && xhr.status == 200) {
// console.log(xhr.responseText);
box.innerHTML = xhr.responseText;
}
}
}

php中

<?php
echo "成功了";
?>
// 总结将打印内容返回到js中xhr的responseText属性中

总结

AJAX实质上也是遵循Request/Server模式,所以这个框架基本的流程是:

一、对象初始化

二、发送请求

三、服务器接收

四、服务器返回

五、客户端接收

六、修改客户端页面内容。

只不过这个过程是异步的。

AJAX的原理的更多相关文章

  1. Ajax工作原理

    在写这篇文章之前,曾经写过一篇关于AJAX技术的随笔,不过涉及到的方面很窄,对AJAX技术的背景.原理.优缺点等各个方面都很少涉及null.这次写这篇文章的背景是因为公司需要对内部程序员做一个培训.项 ...

  2. 关于Ajax工作原理

    1.ajax技术的背景 不可否认,ajax技术的流行得益于google的大力推广,正是由于google earth.google suggest以及gmail等对ajax技术的广泛应用,催生了ajax ...

  3. Ajax工作原理(转)

    1.ajax技术的背景 不可否认,ajax技术的流行得益于google的大力推广,正是由于google earth.google suggest以及gmail等对ajax技术的广泛应用,催生了ajax ...

  4. ajax请求原理及jquery $.ajax封装全解析

    .ajax原理: Ajax的原理简单来说通过XmlHttpRequest对象来向服务器发异步请求,从服务器获得数据,然后用javascript来操作DOM而更新页面.这其中最关键的一步就是从服务器获得 ...

  5. Ajax的原理和运行机制

    关于ajax,是最近炒得非常火的一种技术,并且时下它也是非常流行.当然,它并不是什么新技术,而是在各种已有的技术和支持机制下的一个统一.在我的项目中,偶尔也会用到ajax,用来给用户一些无刷新的体验. ...

  6. Ajax 技术原理(转)

    Ajax 技术原理 2010-01-04 原文出处:http://www.nowamagic.net/ajax/ajax_AjaxPrinciple.php 在写这篇文章之前,曾经写过一篇关于AJAX ...

  7. (转)Ajax的原理和应用

    1.ajax技术的背景 不可否认,ajax技术的流行得益于google的大力推广,正是由于google earth.google suggest以及gmail等对ajax技术的广泛应用,催生了ajax ...

  8. aJax学习之Ajax工作原理

    转自:http://www.cnblogs.com/mingmingruyuedlut/archive/2011/10/18/2216553.html 在写这篇文章之前,曾经写过一篇关于AJAX技术的 ...

  9. ajax请求原理

    首先分析使用ajax时候有那些不确定的因素 请求:1 请求的方式不确定 2 请求的地址不确定 3 请求是否异步不确定 4 发送的数据不确定 响应:5 返回的数据不确定 6 响应成功之后 需要处理的业务 ...

  10. ajax的原理解析

    一.关于同步与异步的分析: 异步传输是面向字符的传输,它的单位是字符:而同步传输是面向比特的传输,它的单位是桢,它传输的时候要求接受方和发送方的时钟是保持一致的.而ajax就是采用的异步请求方式的. ...

随机推荐

  1. ionic3隐藏子页面的tabs和配置返回按钮

    在app.modlues.ts文件中修改 imports: [ BrowserModule, IonicModule.forRoot(MyApp, { tabsHideOnSubPages: 'tru ...

  2. Django异步任务之Celery

    Celery celery 是一个用于实现异步任务的库, 在很多项目中都使用它, 它和 django 融合使用很完美. 使用 celery 可以在实现 http request请求返回 view 前做 ...

  3. NOIP 2019游记

    Update on 2019.4.20 禁赛预定

  4. TCPDUMP 使用教程

    TCPDUMP 命令使用简介 简单介绍 tcpdump 是一款强大的网络抓包工具,运行在 Linux 平台上.熟悉 tcpdump 的使用能够帮助你分析.调试网络数据. 要想很好地掌握 tcpdump ...

  5. 在vue中关于element UI 中表格实现下载功能,表头添加按钮,和点击事件失效的解决办法。

    因为在element 中表格是使用el-table的形式通过数据来支撑结构,所以,表格的样式没有自己写的灵活,所以有了没法添加按钮的烦恼.下面是解决的方法. 准备工作: 一.下载npm安装包两个 1. ...

  6. Angular记录(6)

    文档资料 箭头函数--MDN:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Functions/Arrow_fun ...

  7. Python 中使用 matplotlib 绘图中文字符显示异常的问题

    最近在使用 Python matplotlib 绘制图表时发现中文字符不能正确显示:比如在绘制折线图时,中文全部显示成▢▢▢的格式,虽然将数据改成英文就没什么问题,但是所有数据都这么做时不可行的,于是 ...

  8. DirectX11--教程项目无法编译、运行的解决方法

    综述 对于Win10系统的大多数用户来说,可以直接编译本教程对应的项目并运行.但也有部分用户由于某些原因可能会出现无法编译的情况. DirectX11 With Windows SDK完整目录 欢迎加 ...

  9. 使用Docker安装SonarQube

    需先安装docker和docker-compose.见:https://www.cnblogs.com/hackyo/p/9280042.html 在任意目录下新建文件docker-compose.y ...

  10. hive 时间函数

    使用时发现:1.datediff可以传入timestamp类型参数     官网文档: Date Functions The following built-in date functions are ...