ajax高频面试问题总结

更新日期: 2021-01-01 阅读: 2.2k 标签: 面试

一、什么是 aja?

是一种异步请求数据的web开发技术,它可以在不提交整个页面的情况下,向服务器发送请求,实现页面的局部刷新

目的:可以带来更好的用户体验,按需获取数据,节约带宽资源


二、ajax的原理?

首先举个例子:假如领导想让小王汇报一下工作,就委托秘书去叫小王,自己接着做其他事情,直到秘书告诉他小王已经到了,最后小王和领导汇报工作

ajax请求数据流程与之类似,其中最核心的依赖是浏览器提供的XMLHttpRequest对象,它扮演的角色相当于秘书,使得浏览器可以发出请求和接收响应。浏览器接着做其他事情,等接收到XHR返回来的数据后再渲染页面


三、ajax请求数据的过程?

创建一个'XMLHttpRequest'异步调用对象

创建一个新的HTTP请求,并指定请求的方法、URL及验证信息

设置响应HTTP请求状态变化的函数

发送HTTP请求

获取异步调用返回的数据

使用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都有哪些优点和缺点?

ajax的优点:

最大的优点是页面无刷新,用户的体验非常好

使用异步方式与服务器通信,具有更加迅速的响应能力

ajax的原则是“按需取数据”,可以最大程度的减少冗余请求,减轻服务器和带宽的负担

基于标准化并被广泛支持的技术,不需要下载插件或者小程序

ajax的缺点

ajax不支持浏览器back按钮

安全问题 ,ajax暴露了与服务器交互的细节

对搜索引擎的支持比较弱

破坏了程序的异常机制


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

HTTP协议状态码表示的意思主要分为五类,大体是:

1××:保留
2××:表示请求成功地接收
3××:为完成请求客户需进一步细化请求
4××:客户错误
5××:服务器错误


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

常见的请求方式: get post delete put

get参数通过url传递,post放在request body中

get方式发送数据时,参数数据队列在url中是可见的,post不可见

get传输速率比较快,post比较慢

get保密性低,post保密性高

get传递的参数是有长度限制的,post没有

get请求只能进行url编码,而post支持多种编码方式


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

同源策略:防止 JavaScript 发起跨域请求,源被定义为协议、主机名和端口号的组合,下面这个图详细的解释了同源


跨域:基于浏览器的同源策略,只有当协议、端口、和域名都相同的页面才具有相同的源。只要有一个不同,就产生跨域问题

解决方法:

jsonp,允许 script 加载第三方资源

nginx反向代理(nginx 服务内部配置 Access-Control-Allow-Origin *)

cors 前后端协作设置请求头部,Access-Control-Allow-Origin 等头部信息

iframe 嵌套通讯,postmessage

原文地址:https://www.cnblogs.com/chenfairy/p/14156294.html  

本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://fly63.com/article/detial/10033

相关推荐

有趣的Js面试题_如何让 (a == 1 && a == 2 && a == 3) 返回 true

题目大意为:JS 环境下,如何让 a == 1 && a == 2 && a == 3 这个表达式返回 true ?这道题目乍看之下似乎不太可能,因为在正常情况下,一个变量的值如果没有手动修改,在一个表达式中是不会变化的。

前端面试之webpack面试常见问题

什么是webpack和grunt和gulp有什么不同?什么是bundle,什么是chunk,什么是module?什么是Loader?什么是Plugin?如何可以自动生成webpack配置?webpack-dev-server和http服务器如nginx有什么区别?

Web前端年后跳槽面试复习指南

很多童鞋可能年后有自己的一些计划,比如换份工作环境,比如对职业目标有了新的打算。当然面试这一关不得不过,大概又不可能系统性的复习,这里罗列一些 重点 面试的知识点和文章,

React常见面试题

React常见面试题:React中调用setState之后发生了什么事情?React中Element与Component的区别?优先选择使用ClassComponent而不是FunctionalComponent?React中的refs属性的作用是什么?React中keys的作用是什么?

毕业一年左右的前端妹子面试总结

把面试当做学习,这个过程你会收益很大。前端知识很杂,可能实际工作中用到的技术,像框架都是跟着公司的要求走的,像我最近也在看React啦,Vue和React都对比着再学习

js练习笔记:10道JavaScript题目

10道JavaScript题目:累加函数addNum、实现一个Person类、实现一个arrMerge 函数、实现一个toCamelStyle函数、setTimeout实现重复调用、实现一个bind函数、实现一个Utils模块、输出一个对象自身的属性

写给程序员的 HR 面试指南

首先,切记不要诋毁你的老东家。你应该把你的离职原因集中表述在“寻找新机会或新的平台”以及尝试在新的岗位上提升自己。当然,这样的回答对于一般职位的应聘者来说不会造成减分

一篇文章教会你面试中的小套路

面试,一个短时间内对某个人做出判断的测试。很多时候,工程师们只准备了相关的技术点,却没有对非技术的软实力部分做准备。而软实力的考察,不仅贯穿整个面试流程中,更在BOSS面和HR面中尤为关键。鉴于当前业界也没有特别契合的攻略文档,仅有有几篇文章还是HR写的,特有此文

CSS 面试知识点总结

最近在整理 CSS 的时候发现遇到了很多面试中常见的面试题,本部分主要原作者在 Github 等各大论坛收录的 CSS 相关知识和一些相关面试题时所做的笔记,分享这份总结给大家,对大家对 CSS 的可以来一次全方位的检漏和排查

vue面试时需要准备的知识点

vue上手可以说是比较轻松而且简单,如果你用过angular,react,你也会很喜欢vue。vue的核心思想依旧是:构建用户界面的渐进式框架,关注视图的变化。这也是为什么新建的文件是结构是template script style

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!