34 PHP与Ajax

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 路老师在知乎上分享了关于PHP语言的知识,帮助大家入门并深入了解PHP。本文重点介绍了Ajax技术,包括其概念、开发模式、优点及常用技术,如JavaScript和XMLHttpRequest对象。Ajax通过异步请求改善了用户体验,减轻了服务器负担,实现了页面无刷新更新。

有胆量你就来跟着路老师卷起来! -- 纯干货,技术知识分享

路老师给大家分享PHP语言的知识了,旨在想让大家入门PHP,并深入了解PHP语言。

image.gif 编辑


上篇文章简单的了解了如何实现多文件上传以及文件的下载功能,本文我们开始进入Ajax的PHP应用技术的学习。

1 Ajax概述

Ajax技术改善了传统Web应用的用户体验,发掘了Web浏览器的潜力,为Web开发开创了大量的新的可能性。

1.1 什么是Ajax

Ajax是由Jesse James Garrett创造的,是Asynchronous JavaScript And XML的缩写,即异步JavaScript和XML技术。Ajax并不是一门新的语言或者技术,它是JavaScript、XML、CSS、DOM等多种已有技术的组合,可以实现客户端的异步请求操作,并可以实现在不需要刷新页面的情况下与服务器进行通信,从而减少用户的等待时间,提高使用效率。

1.2 Ajax 的开发模式

在传统的Web应用模式中,页面中用户的每次操作都将触发一次返回Web服务器的HTTP请求,服务器进行相应的处理后,返回一个HTML页面给客户端。

image.gif 编辑

而Ajax应用中,页面中用户的操作将通过Ajax引擎与服务器端进行通信,然后将返回结果提交给客户端页面的Ajax引擎,再由Ajax引擎来决定将这些数据插入到页面的指定位置。

image.gif 编辑

1.3 Ajax的优点

与传统Web应用不同,Ajax在用户与服务器之间引入一个中间媒介Ajax引擎,Web页面不用打断交互流程进行重新加载即可动态地更新,从而消除了网络交互过程中的“处理--等待--处理--等待”的缺点。

使用Ajax的有点具体如下:

  • 减轻服务器的负担。Ajax的原则是“按需求获取数据”,可以最大程度地减少由于冗余请求和响应对服务器造成的负担。
  • 可以把一部分以前由服务器担负的工作转移到客户端,利用客户端闲置的资源进行处理,减轻服务器和带宽的负担,节约空间和宽带租用成本。
  • 无刷新更新页面,使用户不用再像以前一样在服务器处理数据时,只能在死板的白屏前焦急地等待。Ajax使用XMLHttpRequest对象发送请求并得到服务器响应,在不需重新载入整个页面的情况下,即可通过DOM及时将更新的内容显示在页面上。
  • 可以调用XML等外部数据,进一步实现Web页面显示和数据的分离。

2 Ajax使用的技术

2.1 Ajax与JavaScript

Ajax利用JavaScript将DOM、HTML、XML以及CSS等技术综合起来,并控制它们的行为。因此,要开发一个复杂、高效的Ajax应用程序,就必须要对JavaScript有一定了解。

2.2 XMLHttpRequest对象

Ajax技术中,最核心的技术就是XMLHttpRequest,它是一个具有应用程序接口的JavaScript对象,能够使用超文本传输协议(HTTP)连接服务器,是微软公司为了满足开发者需要,与1999年在IE5.0浏览器率先推出的。

通过XMLHttpRequest对象,Ajax可以像桌面应用程序一样只同服务器进行数据层面的交换,而不用每次都刷新页面,也不用每次都将数据处理的工作交给服务器来做,这样既减轻了服务器负担又加快了响应速度,从而缩短了用户等待的时间。

在使用XMLHttpRequest对象发送请求和处理响应之前,首先需要初始化该对象,由于XMLHttpRequest对象还没有标准化,所以对于不同的浏览器,初始化的方法还不同。

IE浏览器

var http_request = new ActiveXObject("Msxml2.XMLHTTP")
//或者
var http_request = new ActiveXObject("Microsoft.XMLHTTP")

image.gif

其他浏览器(Google 、Mozilla等)

var http_request = new XMLHttpRequest();

image.gif

为了提高程序的兼容性,可以创建一个跨浏览器的XMLHttpRequest对象,方法如下:

if(window.XMLHttpRequest) {
    http_request = new XMLHttpRequest();
}else if(window.ActiveXObject){
    try {
        http_request = new ActiveXObject("Msxml2.XMLHTTP");
    } catch (e) {
        try {
            http_request = new ActiveXObject("Microsoft.XMLHTTP");
        } catch (e1) {
            alert("您的浏览器不支持Ajax");
            return false;
            
        }
    }
}

image.gif

2.3 XMLHttpRequest对象的常用方法

2.3.1 open()方法

该方法用于设置进行异步请求目标的URL、请求方法以及其他参数信息,具体语法如下:

open("method", "URL" [,asyncFlag[,"userName"[,"password"]]])

image.gif

  • method 用于指定请求类型,一般为get或post;
  • URL用于请求的地址
  • asyncFlag用于指定请求方式,异步请求为true,同步请求为false,默认情况下为true;
  • userName为指定用户名,可省略;
  • password用于指定请求密码,可省略

2.3.2 send()方法

用于向服务器发送请求。如果请求声明为异步,该方法将立即返回,否则将到接收到响应为止:

send(content)
//content为指定发送的数据,可以是DOM对象实例、输入流或者字符串,没有可传递null

image.gif

2.3.3 setRequestHeader()方法

为请求HTTP设置请求头:

setRequestHeader("label", "value")

image.gif

2.3.4 abort()方法

用于停止当前异步请求

2.3.5 getAllResponseHeaders()方法

用于以字符串形式返回完整的HTTP头信息,当存在参数时,表示以字符串形式返回由该参数指定的HTTP头信息。

2.4 XMLHttpRequest对象的常用属性

属性 说明
onreadystatechange 每个状态改变时都会触发这个事件处理器,通常会调用一个JavaScript函数
readyState

请求的状态。由如下5个取值:

0=未初始化

1=正在加载

2=已加载

3=交互中

4=完成

responseText 服务器的响应,表示为字符串
responseXML 服务器的响应,表示为XML。这个对象可以解析为一个DOM对象
status

返回服务器的HTTP状态码,如:

200=“成功”

202=“请求被接收,但尚未成功”

400=“错误的请求”

404=“文件未找到”

500=“内部服务器错误”

statusText 返回HTTP状态码对应的文本

下一篇  Ajax 技术检测用户名是否被占用

相关文章
|
26天前
|
XML 前端开发 JavaScript
PHP与Ajax在Web开发中的交互技术。PHP作为服务器端脚本语言,处理数据和业务逻辑
本文深入探讨了PHP与Ajax在Web开发中的交互技术。PHP作为服务器端脚本语言,处理数据和业务逻辑;Ajax则通过异步请求实现页面无刷新更新。文中详细介绍了两者的工作原理、数据传输格式选择、具体实现方法及实际应用案例,如实时数据更新、表单验证与提交、动态加载内容等。同时,针对跨域问题、数据安全与性能优化提出了建议。总结指出,PHP与Ajax的结合能显著提升Web应用的效率和用户体验。
40 3
|
3月前
|
XML 前端开发 JavaScript
php中Ajax的简单使用,登录表单调用Ajax判断是否正确登录利用layer.msg进行提示
本文介绍了在PHP中如何使用Ajax进行登录表单的数据提交,并利用jQuery的$.post()方法与后端通信,以及使用layer.msg进行前端提示。
php中Ajax的简单使用,登录表单调用Ajax判断是否正确登录利用layer.msg进行提示
|
6月前
|
PHP
php+ajax传file文件数据
php+ajax传file文件数据
49 0
|
7月前
|
前端开发 JavaScript PHP
【PHP开发专栏】jQuery与PHP实现Ajax通信
【4月更文挑战第30天】本文介绍了使用jQuery和PHP实现Ajax通信的步骤。首先,讲解了Ajax的基础和jQuery简化Ajax操作的概念。接着,展示了如何使用jQuery的`$.get()`、`$.post()`和`$.ajax()`方法发送GET和POST请求,以及如何控制请求细节。在PHP端,讨论了接收和响应Ajax请求的方法,包括处理数据、设置响应类型和错误处理。结合jQuery与PHP,开发者能实现高效、无缝的异步数据传输,提升Web应用的用户体验。
131 1
|
7月前
|
XML 前端开发 JavaScript
【PHP 开发专栏】PHP 与 Ajax 交互开发
【4月更文挑战第30天】本文探讨了PHP与Ajax交互在Web开发中的应用。Ajax负责客户端的异步请求,PHP处理服务器端业务逻辑。两者结合实现高效、流畅的用户体验。文中阐述了Ajax的工作原理,PHP的角色,数据传输格式选择,并提供了发送Ajax请求、PHP处理请求的示例代码。实际应用包括实时数据更新、表单验证和动态内容加载。开发中需注意跨域、数据安全和性能优化。PHP与Ajax的结合将继续在Web开发中发挥重要作用。
86 0
|
7月前
|
前端开发 JavaScript 关系型数据库
PHP代码合集21个邮箱2个问答23个ajax特效
PHP代码合集21个邮箱2个问答23个ajax特效
34 0
|
前端开发 PHP 数据安全/隐私保护
【PHP学习】—利用ajax原理实现密码修改功能(九)
【PHP学习】—利用ajax原理实现密码修改功能(九)
|
前端开发 JavaScript PHP
【PHP学习】—利用ajax原理实现登录功能(八)
【PHP学习】—利用ajax原理实现登录功能(八)
|
JSON 前端开发 安全
ajax中实现访问url已阅即焚的解决方案(url动态参数、变量加密、常量不变、php加密解密、API访问验证方式)
ajax中实现访问url已阅即焚的解决方案(url动态参数、变量加密、常量不变、php加密解密、API访问验证方式)
291 0
|
前端开发 JavaScript 关系型数据库
宝塔设置PHP定时任务实战记录(定时任务、ajax异步刷新API、shell脚本、访问url)
宝塔设置PHP定时任务实战记录(定时任务、ajax异步刷新API、shell脚本、访问url)
779 0