一、二者区别
1.理论区别:
(1)axios是通过Promise实现对ajax技术的一种封装,就像jquery对ajax的封 装一样。(ajax技术实现了局部数据的刷新,axios实现了对ajax的封装。);
(2)axios是ajax,ajax不止axios;axios有的ajax都有,ajax有的axios不一 定有。
2.代码区别:
1.axios
axios({
url: '/getName',
method: 'get',
responseType: 'json', // 默认的
data: {
name:'tom'
}
}).then(function (response) {
console.log(response);
console.log(response.data);
}).catch(function (error) {
console.log(error);
});
2.ajax
$.ajax({
url: '/getName',
type: 'get',
dataType: 'json',
data: {
name:'tom'
},
success: function (response) {
console.log(response);
}
})
3.逻辑区别:
1.ajax本身是针对MVC的编程:
最典型的MVC就是jsp+servlet+javabean模式
JavaBean作为模型,既可以作为数据模型来封装业务数据,又可以作为业务逻辑模型来包含应用的业务操作。
JSP作为表现层,负责提供页面为用户展示数据,提供相应的表单(Form)来用于用户的请求,并向控制器发出请求来请求模型进行更新。
Serlvet作为控制器,用来接收用户提交的请求,然后获取请求中的数据,将之转换为业务模型需要的数据模型,然后调用业务模型相应的业务方法进行更新,同时根据业务执行结果来选择要返回的视图。
2.axios符合现在前端MVVM的浪潮 :
ViewModel 层,它就像是一个中转站,负责转换 Model 中的数据对象,该层向上与视图层进行双向数据绑定,向下与 Model 层通过接口请求进行数据交互,起呈上启下作用。
View 层展现的不是 Model 层的数据,而是 ViewModel 的数据,由 ViewModel 负责与 Model 层交互,这就完全解耦了 View 层和 Model 层。
二、优缺点
1.axios优点:
(1)从浏览器中创建 XMLHttpRequest;
(2)支持 Promise API;
(3)从 node.js 创建 http 请求;
(4)转换请求和响应数据;
(5)自动转换JSON数据。
1.ajax缺点:
(1)基于原生的XHR开发,XHR本身的架构不清晰;
(2)JQuery整个项目太大,单纯使用ajax却要引入整个JQuery非常的不合理;
(3)不符合关注分离(Separation of Concerns)的原则;
(4)配置和调用方式非常混乱,而且基于事件的异步模型不友好。
三、总结:
学习上:
上个星期李老师正式发布课题任务之后就开始了静态页面的排版,至此已经完成了几个简单的静态页面和一下promise和以上axios的学习,下一步要进行接口的访问,数据的遍历以及静态页面的完善,这次需要些原生的js和一下表单,所以前提可能需要的时间多一些,但还是尽快完成比较好,为后面的阶段腾时间。下周要进行期末考试了,要认真复习,防止专业课成绩不理想。
生活上:
双11的时候买了一下厚的衣服,还没有到,最近因为新生,也一组没有闲着,他们也都挺努力, 希望他们能一直坚持下来。
更多推荐
浅谈axios和ajax区别
发布评论