不使用XMLHttpRequest对象实现Ajax效果的方法小结
我们通常一提到Ajax,首先想到的就是XMLHttpRequest对象。但如果你认为无刷新的异步请求只此一条路,那就把格局想小了。今天,我们就来聊聊几种不依赖XMLHttpRequest,同样能实现Ajax效果的“野路子”。
前言
很多朋友初次接触Ajax,可能都是通过jQuery的$.ajax()这类封装好的API,用起来方便,但对底层的实现原理未必深究过。了解这些原理和替代方案,不仅能深化对Web通信的理解,在某些特定场景下,或许还能成为解决问题的奇兵。下面分享的几种方法,都附有实例,希望能带来一些启发。
Ajax原理的精髓
说到底,Ajax的核心目标很简单:在页面不发生整体刷新的前提下,与服务器进行数据交互,并更新局部内容。虽然XMLHttpRequest是实现这一目标的标配,但绝非唯一答案。
目标与方法
我们的目标很明确:用Ja vaScript发起对后台的请求,同时确保页面不跳转、不刷新。实现这个目标,至少有三种典型的思路值得探讨:
(1)利用HTTP 204 No Content状态码的特性。
(2)巧用图片等资源的加载机制。
(3)借助iframe元素来“暗度陈仓”。
1、巧用204状态码:让浏览器“静默”处理响应
原理
当服务器返回状态码204(No Content)时,它是在明确告诉浏览器:“请求成功了,但我没有返回任何内容给你。”对于浏览器而言,收到这样的响应,其标准行为就是——什么都不做,页面状态自然保持不变。这就为我们实现无刷新操作提供了一个天然的“后门”。
案例:无刷新投票系统
设想一个简单的投票页面,点击按钮,票数+1,但页面其他部分纹丝不动。用204状态码就能优雅地实现。
文件结构图:

01-vote.html文件
这就是前端的投票界面,核心是一个指向处理程序的链接。
无刷新投票界面 无刷新投票界面
![]()
01-vote.php文件
后端的逻辑是读写文件计票,关键在于最后一行:发送204状态码头。
<?php
/**
* 投票程序
* @author webbc
*/
$number = file_get_contents('./01-vote-res.txt');//读取文件内容
$number++;//加1
file_put_contents('./01-vote-res.txt',$number);//重写到文件中
//服务器发送响应头204,前端不会响应,使前端达到ajax效果
header('HTTP/1.1 204 No Content');
?>
效果图
点击“投票”链接,你会看到请求发生了(可以从网络面板观察到),但当前页面静默无声,没有任何刷新或跳转的迹象,如同什么都没发生,其实票数已经默默增加了。

2、图片加载:最朴素的HTTP请求触发器
原理
浏览器遇到img标签,或者Ja vaScript动态设置了图片的src属性,都会立刻向指定地址发起一个GET请求。这个行为是单向的——我们只关心请求是否发出,并不真的需要显示一张图片。利用这一点,就能神不知鬼不觉地向服务器发送信号。
案例(续投票程序)
还是那个投票功能,这次我们用图片来触发。
文档结构图:

02-vote.html文件
将链接的点击事件绑定到一个函数,该函数会动态创建一个图片元素,并将其src设为后端地址。
无刷新投票界面 无刷新投票界面
![]()
02-vote.php文件
后端处理逻辑与之前类似,但这次不需要特意发送204状态码了。
<?php
/**
* 投票程序
* @author webbc
*/
$number = file_get_contents('./02-vote-res.txt');//读取文件
$number++;//加1
file_put_contents('./02-vote-res.txt',$number);//重新写回文件
?>
这种方法的效果与第一种完全一致,页面同样不会刷新。
3、利用iframe:创造一个“隐形”的请求袋里
原理
iframe元素能在当前页面内嵌一个独立的文档窗口。关键来了:我们可以将表单的target属性指向这个隐藏的iframe。这样一来,表单提交的请求和响应全部发生在这个内部的“小窗口”里,主页面自然稳如泰山。然后,我们再用Ja vaScript通过parent对象,实现内外页面之间的通信,从而更新主页面的内容。
案例:无刷新用户注册
这是一个更接近传统Ajax应用的例子:提交表单,后端验证,并实时在主页面显示结果。
文件结构图:
01-reg.html文件
注意表单的target="reg",以及那个被设置为不可见的iframe。
无刷新注册界面 无刷新用户注册界面
01-reg.php文件
后端处理数据后,不是直接返回数据,而是返回一段能操作父页面(即主页面)DOM的Ja vaScript代码。
<?php
/**
* 注册程序
* @author webbc */
header('Content-type:text/html;charset=utf-8');//设置编码
if(trim($_POST['username']) === '' || trim($_POST['email']) === ''){//如果用户名或邮箱都为空
echo '';//在主界面输出"信息不完整"
exit;
}
echo '';//在主界面输出"注册成功"
?>
效果图
填写信息点击注册,页面丝毫不动,但下方的提示区域却即时地显示出“注册成功”或“信息不完整”的反馈,完整体验了无刷新交互。

当然,这些方法在现代前端开发中大多已被更强大、更规范的XMLHttpRequest或Fetch API所取代。但它们揭示了Web早期为了实现异步交互所展现出的智慧与灵活性。理解这些,有助于我们更全面地认识Web技术的发展脉络。
希望这些“古典”技法,能为你深入理解Ajax原理,带来一些不一样的视角和思考。