浅谈axios和ajax区别

一、二者区别

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的时候买了一下厚的衣服,还没有到,最近因为新生,也一组没有闲着,他们也都挺努力, 希望他们能一直坚持下来。

你可能感兴趣的:(心得,ajax)