ajax高频面试问题总结

时间:2021-01-01 12:46:02   收藏:0   阅读:0

一、什么是 aja?

二、ajax的原理?

三、ajax请求数据的过程?

  1. 创建一个‘XMLHttpRequest‘异步调用对象
  2. 创建一个新的HTTP请求,并指定请求的方法、URL及验证信息
  3. 设置响应HTTP请求状态变化的函数
  4. 发送HTTP请求
  5. 获取异步调用返回的数据
  6. 使用JavaScript和DOM实现局部刷新
var xhr = new XMLHttpRequest();   // 初始化请求对象
xhr.open("get/post", "路径", "true/false");   // 设置请求方式,请求地址 ,异步(true  默认的)和同步(false  强烈不推荐使用,已被弃用)
xhr.send();
xhr.onreadystatechange = function () {  //  2 = 加载完毕(loaded),请求已接收头信息;3 = 交互 ,请求处理中,已接收主体信息;4 = 完成(complete),响应已完成(返回响应结果:成功/重定向/不存在/服务器有问题)
       if (xhr.readyState == 4 && xhr.status == 200) {   // xhr.readyState:请求的状态;xhr.status:服务器返回的响应状态(成功 200,重定向 300,不存在 400,服务器有问题 500)
            var result = JSON.parse(xhr.responseText);
       }
 }

四、ajax都有哪些优点和缺点?

  1. 最大的优点是页面无刷新,用户的体验非常好
  2. 使用异步方式与服务器通信,具有更加迅速的响应能力
  3. ajax的原则是“按需取数据”,可以最大程度的减少冗余请求,减轻服务器和带宽的负担
  4. 基于标准化并被广泛支持的技术,不需要下载插件或者小程序
  1. ajax不支持浏览器back按钮
  2. 安全问题 ,ajax暴露了与服务器交互的细节
  3. 对搜索引擎的支持比较弱
  4. 破坏了程序的异常机制

五、http常见状态码有哪些?

https://www.cnblogs.com/chenfairy/p/14201743.html

六、ajax的几种请求方式以及优缺点?

  1. get参数通过url传递,post放在request body中
  2. get方式发送数据时,参数数据队列在url中是可见的,post不可见
  3. get传输速率比较快,post比较慢
  4. get保密性低,post保密性高
  5. get传递的参数是有长度限制的,post没有
  6. get请求只能进行url编码,而post支持多种编码方式

七、什么是同源策略以及跨域是什么?

  1. jsonp,允许 script 加载第三方资源
  2. nginx反向代理(nginx 服务内部配置 Access-Control-Allow-Origin *)
  3. cors 前后端协作设置请求头部,Access-Control-Allow-Origin 等头部信息
  4. iframe 嵌套通讯,postmessage
评论(0
© 2014 mamicode.com 版权所有 京ICP备13008772号-2  联系我们:gaon5@hotmail.com
迷上了代码!