Ajax的技术与原理

Ajax的简介

  • AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。
  • AJAX 不是新的编程语言,而是一种使用现有标准的新方法。
  • AJAX 是与服务器交换数据并更新部分网页的艺术,在不重新加载整个页面的情况下。
    原理
  • 通过 XMLHttpRequest 与服务器交换数据
  • 服务数据通过json 或者 xml格式返回
  • 浏览器端通过js+ccs渲染展示数据
    原生ajax
    get请求:
btn.onclick = function(){ //按钮单击事件// 01 创建xhrvar xhr = new XMLHttpRequest();// 02 open打开连接xhr.open("GET",'./be.txt',false);        // 03 监听readystate  readyState 4准备状态完毕//  status 状态码200 响应成功xhr.onreadystatechange=function(){if(xhr.status==200&&xhr.readyState==4){content.innerHTML= xhr.responseText;// responseText 返回的文本}}// 04 send 发送xhr.send();// 05 实现渲染    }

post请求:

// 01 创建xhr对象var xhr = new XMLHttpRequest();// 02 获取数据var name = document.getElementById("name").value;var age =  document.getElementById("age").value;// 03 建立连接xhr.open("POST","http://localhost/echo.php",false);// 04 监听xhr.onreadystatechange = function(){if(xhr.status==200&&xhr.readyState==4){content.innerHTML = xhr.responseText;}}xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');//设置编码形式xhr.send(`name=${name}&age=${age}`);//发送}

jquery中ajax
第一层:$.ajax()
第二层: $.get() $.post()
回调函数
$.get(url,function(data,status,xhr){})
.done()
.fail()
.always()
.then()
.catch()
$.post(url,data,function(data,status,xhr))
第三层
$.getJSON()
$.getScript()
load()
GET和POST 的区别,何时使用POST ?
GET:一般用于信息获取,使用 URL 传递参数,对所发送信息的数量也有限制,一般在2000 个字符,有的浏览器是 8000 个字符
POST:一般用于修改服务器上的资源,对所发送的信息没有限制
在以下情况中,请使用 POST 请求:

ajax的优点

<1>.无刷新更新数据。
AJAX最大优点就是能在不刷新整个页面的前提下与服务器通信维护数据。这使得Web应用程序更为迅捷地响应用户交互,并避免了在网络上发送那些没有改变的信息,减少用户等待时间,带来非常好的用户体验。
<2>.异步与服务器通信。
AJAX使用异步方式与服务器通信,不需要打断用户的操作,具有更加迅速的响应能力。优化了Browser和Server之间的沟通,减少不必要的数据传输、时间及降低网络上数据流量。
<3>.前端和后端负载平衡。
AJAX可以把以前一些服务器负担的工作转嫁到客户端,利用客户端闲置的能力来处理,减轻服务器和带宽的负担,节约空间和宽带租用成本。并且减轻服务器的负担,AJAX的原则是“按需取数据”,可以最大程度的减少冗余请求和响应对服务器造成的负担,提升站点性能。
<4>.基于标准被广泛支持。
AJAX基于标准化的并被广泛支持的技术,不需要下载浏览器插件或者小程序,但需要客户允许JavaScript在浏览器上执行。随着Ajax的成熟,一些简化Ajax使用方法的程序库也相继问世。同样,也出现了另一种辅助程序设计的技术,为那些不支持JavaScript的用户提供替代功能。
<5>.界面与应用分离。
Ajax使WEB中的界面与应用分离(也可以说是数据与呈现分离),有利于分工合作、减少非技术人员对页面的修改造成的WEB应用程序错误、提高效率、也更加适用于现在的发布系统。

AJAX的缺点

<1>.AJAX干掉了Back和History功能,即对浏览器机制的破坏。
在动态更新页面的情况下,用户无法回到前一个页面状态,因为浏览器仅能记忆历史记录中的静态页面。一个被完整读入的页面与一个已经被动态修改过的页面之间的差别非常微妙;用户通常会希望单击后退按钮能够取消他们的前一次操作,但是在Ajax应用程序中,这将无法实现
<2>.AJAX的安全问题。
AJAX技术给用户带来很好的用户体验的同时也对IT企业带来了新的安全威胁,Ajax技术就如同对企业数据建立了一个直接通道。这使得开发者在不经意间会暴露比以前更多的数据和服务器逻辑。Ajax的逻辑可以对客户端的安全扫描技术隐藏起来,允许黑客从远端服务器上建立新的攻击。还有Ajax也难以避免一些已知的安全弱点,诸如跨站点脚步攻击、SQL注入攻击和基于Credentials的安全漏洞等等。
<3>.对搜索引擎支持较弱。
对搜索引擎的支持比较弱。如果使用不当,AJAX会增大网络数据的流量,从而降低整个系统的性能.
<4>.破坏程序的异常处理机制。
至少从目前看来,像Ajax.dll,Ajaxpro.dll这些Ajax框架是会破坏程序的异常机制的。关于这个问题,曾在开发过程中遇到过,但是查了一下网上几乎没有相关的介绍。后来做了一次试验,分别采用Ajax和传统的form提交的模式来删除一条数据……给我们的调试带来了很大的困难。
<5>.违背URL和资源定位的初衷。
例如,我给你一个URL地址,如果采用了Ajax技术,也许你在该URL地址下面看到的和我在这个URL地址下看到的内容是不同的。这个和资源定位的初衷是相背离的。
<6>.AJAX不能很好支持移动设备。
一些手持设备(如手机、PDA等)现在还不能很好的支持Ajax,比如说我们在手机的浏览器上打开采用Ajax技术的网站时,它目前是不支持的。
<7>.客户端过肥,太多客户端代码造成开发上的成本。
编写复杂、容易出错 ;冗余代码比较多(层层包含js文件是AJAX的通病,再加上以往的很多服务端代码现在放到了客户端);破坏了Web的原有标准。
Ajax适用场景

  • <1>.表单驱动的交互
  • <2>.深层次的树的导航
  • <3>.快速的用户与用户间的交流响应
  • <4>.类似投票、yes/no等无关痛痒的场景
  • <5>.对数据进行过滤和操纵相关数据的场景
  • <6>.普通的文本输入提示和自动完成的场景
    Ajax不适用场景
  • <1>.部分简单的表单
  • <2>.搜索
  • <3>.基本的导航
  • <4>.替换大量的文本
  • <5>.对呈现的操纵
    浏览器同源策略
  • 当浏览器去访问服务器资源(ajax) 要求服务器的地址与浏览器同源
  • 协议,域名,子域名,端口号要一致

跨域

**绕过浏览器的同源策略,请求到数据**
**跨域方式**
  • 1.服务器响应头信息跨域:Access-Control-Allow-Origin: *
  • 2.jsonp跨域
  • 3.服务器代理(开发)
    异步和同步的区别: 同步阻塞代码执行

前端工程师的一生之敌ajax相关推荐

  1. 电商前端工程师:国内WEB前端开发经验之路

    一直想写这篇"十日谈",聊聊我对Web前端开发的体会,顺便解答下周围不少人的困惑和迷惘.我不打算聊太多技术,我想,通过技术的历练,得到的反思应当更重要. 我一直认为自己是" ...

  2. 前端工程师的成长之路

    一直想写这篇"十日谈",聊聊我对Web前端开发的体会,顺便解答下周围不少人的困惑和迷惘.我不打算聊太多技术,我想,通过技术的历练,得到的反思应当更重要. 我一直认为自己是" ...

  3. 前端工程师现在需要掌握的是什么?

    企业招聘要求: 1.ps基础和核心/HTML5/CSS3 2.Jquery.Ajax.Bootrap.Angular.js 3.HTTP协议.服务端开发技术 4.UI交互设计 5.微信开发技术.HTM ...

  4. 写给刚入门的前端工程师的前后端交互指南

    转自原文 写给刚入门的前端工程师的前后端交互指南 作为刚接触前端的不久的童鞋,大家都会兴奋于CSS和JS所带来漂亮界面,然而,前端工程师除了UI重构外,还有非常重要的职责在正确的区域渲染出服务端的数据 ...

  5. 「北京」「10-30k」「华米科技(小米手环)」招前端工程师

    公司 华米科技 Huami, Inc. 华米科技创立于2013年,是一家在智能穿戴技术领域有着丰富生物特征识别经验和运动数据驱动的公司,拥有全球用户海量的生物识别与运动数据库,为用户提供综合评估及分析 ...

  6. 对前端来说token代表了什么_在线公开课 | 前端工程师如何突破瓶颈更好地变现自己...

    课程概要 此次课程的分享主题是"前端工程师如何突破瓶颈更好地变现提升自己".课程从以下三个方面入手,为大家详解一个前端工程师是如何一步步完善并提升自己的的. 前端工程师所应具备的能 ...

  7. 淘宝前端工程师:国内前端行业十日谈(六)

    第六日:码农的宿命 [青春饭] "码农"是IT从 业者一个自嘲的称号,也有从事没有发展前景的软件开发职位,靠写代码为生的意思.但我认为码农是一个爱称,编码的农民,和农民一样有着执着 ...

  8. 前端工程师的知识体系

    前端开发的核心是HTML + CSS + JavaScript.本质上它们构成一个MVC框架,即HTML作为信息模型(Model),CSS控制样式(View),JavaScript负责调度数据和实现某 ...

  9. 想成为一名优秀的Web前端工程师,这5点你要知道

    很多刚学Web前端的人都会有这样的疑问:"怎样学Web前端才能成为一名优秀的Web前端工程师"?想成为一名优秀的Web前端工程师,这5点你必须知道.下面跟着小千一起来看看吧. 1. ...

最新文章

  1. 只要努力搞,没有KPI搞不垮的团队?
  2. 关于 npm 中 lru-cache 之 maxAge 盲点 源码分析
  3. 前端最新技术学习地址总结
  4. Spark源码阅读02-Spark核心原理之作业执行原理
  5. 在类模板的声明和定义中把.h与.cpp分离
  6. LC-BLSTM结构快速解读
  7. 对于新生代农民工,你有什么想说的?
  8. jdk 安装_Linux安装JDK操作手册
  9. arcgis软件界面字体太小
  10. 怎样邀请别人加入企业微信?
  11. Flash 原版官网下载
  12. 网络工程师笔记--广域网和接入网
  13. 对51job网页招聘信息的简单爬取
  14. When and why vgs command can change metadata and incur old metadata to be backed up?
  15. 地图定位技术揭秘(三)
  16. 推荐7个深耕多年的公众号
  17. Jina文章转载:多模态AI的范式变革多模态AI总结(2022年COLING会议)
  18. 嵌入式Web开发——Boa服务器移植
  19. linux debian硬盘安装,硬盘安装Debian
  20. 一个火鸡界大数据学家的一生

热门文章

  1. PPT:如何在ppt中显示网页,并且实时操作?
  2. C# 简单四舍五入函数
  3. Unity3d的WebGL发布和IIS部署
  4. 上海有望制定国内首个IT服务外包标准
  5. 【HDOJ】1017 A Mathematical Curiosity_天涯浪子_新浪博客
  6. 未来30年的研究预测——新书上架(《超限未来10大趋势》)
  7. 践行绿色交通 高速公路再出发
  8. HDU 5945 Fxx and game 单调队列优化dp
  9. Python第一行代码
  10. mysql 餐饮管理系统_餐饮管理系统的设计与实现(MySQL)