问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
你好,欢迎来到懂视!登录注册
当前位置: 首页 - 正文

简述ajax原理和优点

发布网友 发布时间:2022-04-23 05:49

我来回答

3个回答

懂视网 时间:2022-05-13 09:34

说到Ajax大家一定不陌生,但是真要具体说说它是什么?估计给出完整定义的人应该不多。

W3C上给Ajax的具体定义为:

AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。

也就是说AJAX 是与服务器交换数据并更新部分网页的艺术,在不重新加载整个页面的情况下。

AJAX 是一种用于创建快速动态网页的技术。

通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。

传统的网页(不使用 AJAX)如果需要更新内容,必需重载整个网页面。

当然我们在学习Ajax之前必须得先对下面的知识有基本的了解:

  • HTML / XHTML
  • CSS
  • JavaScript / DOM
  • XMLHttpRequest 是 AJAX 的基础。

    所有现代浏览器均支持 XMLHttpRequest 对象(IE5 和 IE6 使用 ActiveXObject)。所有现代浏览器(IE7+、Firefox、Chrome、Safari 以及 Opera)均内建 XMLHttpRequest 对象。

    XMLHttpRequest 用于在后台与服务器交换数据。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。

    具体创建XMLHttpRequest 的代码如下:

    //为了应对所有的现代浏览器,包括 IE5 和 IE6,请检查浏览器是否支持 XMLHttpRequest 对象。如果支持,则创建 XMLHttpRequest 对象。如果不支持,则创建 ActiveXObject var xmlhttp;if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari xmlhttp = new XMLHttpRequest();}else {// code for IE6, IE5 老版本的 Internet Explorer (IE5 和 IE6)使用 ActiveX 对象 xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");}

    再介绍XMLHttpRequest 对象用于和服务器交换数据之前,我们先简单了解一下get和post 方法的利弊,以方便后续开发时选择更加适合的请求方式。

    与 POST 相比,GET 更简单也更快,并且在大部分情况下都能用。

    然而,在以下情况中,请使用 POST 请求:

  • 无法使用缓存文件(更新服务器上的文件或数据库)
  • 向服务器发送大量数据(POST 没有数据量限制)
  • 发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠
  • XMLHttpRequest 与服务器交换数据主要是通过open和send方法,其中如果是open方法中使用的是get方式的话,那么send方法则无需传递任何参数。如果是使用的post方式的话,那么send方法中传递的则是类似于querystring的字符串。

    下面简单介绍一下几个主要的方法:

    方法 描述
    open(method,url,async)

    规定请求的类型、URL 以及是否异步处理请求。

  • method:请求的类型;GET 或 POST
  • url:文件在服务器上的位置
  • async:true(异步)或 false(同步)
  • send(string)

    将请求发送到服务器。

  • string:仅用于 POST 请求
  • setRequestHeader(header,value)

    向请求添加 HTTP 头。

  • header: 规定头的名称
  • value: 规定头的值
  • 事实上,open方法中的async参数如果设计为false的话,那么发送的请求则跟传统的方式没有区别,也就是说必须等待服务器端数据回来之后才能接着进行下步操作。javaScript 会等到服务器响应就绪才继续执行。如果服务器繁忙或缓慢,应用程序会挂起或停止。所以我们不推荐使用 async=false。

    当您使用 async=false 时,请不要编写 onreadystatechange 函数 - 把代码放到 send() 语句后面即可:

    xmlhttp.open("GET", "test1.txt", false);xmlhttp.send();document.getElementById("myDiv").innerHTML = xmlhttp.responseText;

    当使用 async=true 时,请规定在响应处于 onreadystatechange 事件中的就绪状态时执行的函数:

    xmlhttp.onreadystatechange = function () { if (xmlhttp.readyState == 4 && xmlhttp.status == 200) { document.getElementById("myDiv").innerHTML = xmlhttp.responseText; }}xmlhttp.open("GET", "test1.txt", true);xmlhttp.send();

    大家注意当使用async=true 时,它的返回值当中有两个重要的属性,那便是responseText 和responseXML 。其中responseText 获得字符串形式的响应数据而responseXML 获得 XML 形式的响应数据。如果来自服务器的响应并非 XML,请使用 responseText 属性。如果来自服务器的响应是 XML,而且需要作为 XML 对象进行解析,请使用 responseXML 属性。

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

    当 readyState 等于 4 且状态为 200 时,表示响应已就绪

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

    每当 readyState 改变时,就会触发 onreadystatechange 事件。

    readyState 属性存有 XMLHttpRequest 的状态信息。

    下面是 XMLHttpRequest 对象的三个重要的属性:

    属性 描述
    onreadystatechange 存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数。
    readyState

    存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。

  • 0: 请求未初始化
  • 1: 服务器连接已建立
  • 2: 请求已接收
  • 3: 请求处理中
  • 4: 请求已完成,且响应已就绪
  • status

    200: "OK"

    404: 未找到页面

    下面以一个简单的demo温习一下上述介绍的基础知识

      

    热心网友 时间:2022-05-13 06:42

    ajax原理,优劣点
    Ajax 是 Asynchronous JavaScript and XML(以及 DHTML 等)的缩写
    Ajax 尝试建立桌面应用程序的功能和交互性,
    与不断更新的 Web 应用程序之间的桥梁。
    不需要刷新页面就可以将请求提交到后台,
    用户根本感觉不到页面在发送请求或是交换数据.
    Ajax 如何将笨拙的 Web 界面转化成能迅速响应的 Ajax 应用程序。
    下面是 Ajax 应用程序所用到的基本技术:
    HTML 用于建立 Web 表单并确定应用程序其他部分使用的字段。
    JavaScript 代码是运行 Ajax 应用程序的核心代码,帮助改进与服务器应用程序的通信。
    DHTML 或 Dynamic HTML,用于动态更新表单。
    我们将使用div、span和其他动态 HTML 元素来标记 HTML。
    文档对象模型 DOM 用于(通过 JavaScript 代码)处理 HTML 结构和(某些情况下)服务器返回的 XMLXMLHttpRequest 对象

    热心网友 时间:2022-05-13 08:00

    Ajax这个概念的最早提出者Jesse James Garrett认为:Ajax是Asynchronous JavaScript and XML的缩写。Ajax并不是一门新的语言或技术,它实际上是几项技术按一定的方式组合在一在同共的协作中发挥各自的作用,它包括:
    ·使用XHTML和CSS标准化呈现;

    ·使用DOM实现动态显示和交互;

    ·使用XML和XSLT进行数据交换与处理;

    ·使用XMLHttpRequest进行异步数据读取;

    ·最后用JavaScript绑定和处理所有数据;

    Ajax的工作原理相当于在用户和服务器之间加了—个中间层,使用户操作与服务器响应异步化。并不是所有的用户请求都提交给服务器,像—些数据验证和数据处理等都交给Ajax引擎自己来做,只有确定需要从服务器读取新数据时再由Ajax引擎代为向服务器提交请求.

    虽然Garrent列出了7条Ajax的构成技术,但个人认为,所谓的Ajax其核心只有JavaScript、XMLHTTPRequest和 DOM,如果所用数据格式为XML的话,还可以再加上XML这一项(Ajax从服务器端返回的数据可以是XML格式,也可以是文本等其他格式)。

    在旧的交互方式中,由用户触发一个HTTP请求到服务器,服务器对其进行处理后再返回一个新的HTHL页到客户端,每当服务器处理客户端提交的请求时,客户都只能空闲等待,并且哪怕只是一次很小的交互、只需从服务器端得到很简单的一个数据,都要返回一个完整的HTML页,而用户每次都要浪费时间和带宽去重新读取整个页面。
    声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。
    E-MAIL:11247931@qq.com
    王者送皮肤要多少亲密度才能送 王者荣耀 王者荣耀送皮肤需要什么条件? 劳动法裁员补偿工资如何计算 庆余年电视剧第一季结局在小说第几章大概啊?想接着追下去 汽油、柴油价格、航空煤油价格它们每升油提高多少呢? 生产制造ERP管理软件系统 做脑部CT检查的危害 年轻人做脑CT危害 我怀孕快两个月了,前几天陪同家人去做了脑部CT,后悔死了。这样会对我... 做脑ct后悔了怎么办? 突然黑屏怎么也打不开但是过一会又正常了是为什么 毛豆不能和什么一起吃? 电脑突然黑屏打不开了怎么回事 芹菜猪肉蒸饺的做法,芹菜猪肉蒸饺怎么做好吃 Ajax原理 电脑不能装示,处理器不支持装虚拟机,怎么解决? 手机突然黑屏,打不开怎么办? 安装虚拟机时,提示“此处理器类型不支持该安装包”怎么办 毛豆不能和什么同食 手机为什么出现突然黑屏还闪屏就是打不开? 每天晚上喝红酒还需要吃葡萄籽吗 Ajax基于什么技术?其原理是什么? 电脑突然黑屏了,但灯亮着,为什么打不开了,是怎么回事? 吃葡萄时把籽也吃了,这样对身体到底好不好呀? ajax原理: 自制葡萄酒后的葡萄籽如何吃 ajax在jquery的底层是怎么实现的呢? Ajax是什么?工作原理是什么? 葡萄籽吃了有什么好处 Ajax 工作原理? 最新版VMware无法安装,提示cpu不支持,怎么解决(win10) cpu不支持虚拟化技术该怎么办? ajax的工作流程是什么 猪肉芹菜蒸饺怎么做好吃 猪肉芹菜蒸饺最正宗的做法 毛豆不能和什么同食? cpu不支持虚拟化技术该怎么办 手机突然黑屏,怎么都打不开.怎么回事.怎么办 ajax究竟是怎么回事? 为什么微信打不开还黑屏 处理器不支持虚拟化,那如何安装VM虚拟机? 毛豆与什么食物相克 Ajax 原理 安装了虚拟机提示cpu不支持pae 手机突然黑屏,怎么都打不开长按电源键10秒也没用 毛豆为什么不能和鸡蛋一起煮 什么是AJAX? 手机突然黑屏了,怎么也打不开 我电脑是win10系统时,可以安装虚拟机,换了系统装了win7后,再安装虚拟机启动的时候提示该CPU不支持 手机玩着玩着突然黑屏然后开不了机,怎么弄也打不开 ajax异步请求原理
    • 焦点

    最新推荐

    猜你喜欢

    热门推荐