在ajax没出来之前,一直是用iframe实现的无刷新请求。
主要的原理是:
- 使用js创建一个隐藏的iframe
- 把要提交的表单的target属性指向1中生成的iframe
- 在请求的页面中回调父页面的方法
这样就实现了一个简单的“异步提交”
看起来和ajax一样的效果,那为什么还要有ajax,我们来比较下:(以下把ajax技术称为XHR,iframe实现的称为iframe)
XHR 和 iframe的区别主要在4个地方:
- 多线程
从上面说的原理很容易就能看出利用iframe实现的异步请求,其实也还是同步的,也就是说后台在处理这个请求的时候,前台仍然是什么都不能做的;而XHR是真正实现了异步请求,它能发起多个异步请求。
- 回退键
键盘上上的回退键的主要功能是退回到上一个历史页面。
利用iframe实现的异步请求,按回退键是可以回到上个历史页面的;而XHR不行,因为它根本没有留下任何历史的痕迹。
所以现在大多数的搜索引擎是没有利用ajax实现搜索的。
- 跨站访问