首页前端开发其他前端知识ajax重构的定义是什么,重构步骤包括哪些

ajax重构的定义是什么,重构步骤包括哪些

时间2024-03-26 06:12:03发布访客分类其他前端知识浏览921
导读:在这篇文章中我们会学习到关于“ajax重构的定义是什么,重构步骤包括哪些”的知识,小编觉得挺不错的,现在分享给大家,也给大家做个参考,希望对大家学习或工作能有帮助。下面就请大家跟着小编的思路一起来学习一下吧。 a...
在这篇文章中我们会学习到关于“ajax重构的定义是什么,重构步骤包括哪些”的知识,小编觉得挺不错的,现在分享给大家,也给大家做个参考,希望对大家学习或工作能有帮助。下面就请大家跟着小编的思路一起来学习一下吧。
   

ajax重构指的是在不改变软件现有功能的基础上,通过调整程序代码改善软件的质量、性能,使其程序的设计模式和架构更合理,提高软件的扩展性和维护性;Ajax的实现主要依赖于XMLHttpRequest对象,由于该对象的实例在处理事件完成后就会被销毁,所以在需要调用它的时候就要重新构建。

本文操作环境:windows10系统、javascript1.8.5& & html5版、Dell G3电脑。

什么是ajax重构

重构(Refactoring)就是在不改变软件现有功能的基础上,通过调整程序代码改善软件的质量、性能,使其程序的设计模式和架构更趋合理,提高软件的扩展性和维护性。

Ajax的核心对象是XMLHttpReguest,也就是说我们通过Ajax与服务器进行交互,就必须要构建XMLHttpRequest这个对象。

但是在页面之中通过Ajax与服务器进行交互,在交互之后XMLHttpReguest这个对象就会被销毁。

所以我们页面再次通过Ajax与服务器进行交互,还需要重新的构建XMLHttpRequest这个对象。

那么XMLHttpReguest这个对象的创建,我们需要考虑到浏览器的兼容性,所以说XMLHttpReguest的创建也是非常繁琐的,需要根据不同浏览器的类型,来进行不同方式的创建。

那么如果说我们在很多的页面都应用到了Ajax这种技术,我们在很多的页面当中都要来创建这个对象,这就体现不出OO(面向对象这种风格,代码的重复利用),面向对象中提倡代码的重用,所以说我们通常情况下都会通过Ajax重构,来封装XMLHttpReguest这个对象以及封装一些对Ajax请求进行处理的通用方法,那么我们在编写代码的时候就可以直接来引用这个对象,从而来达到代码的重用,也节省了这个对象的创建时间

Ajax重构步骤

1)创建一个单独的JS文件,名字为AjaxRequest.js ,并且在该文件中编写重构Ajax所需的代码

2)在 需要应用Ajax的页面中包括刚刚创建的AjaxRequest.js文件

3)在应用Ajax的页面中编写错误处理的方法,实例化Ajax对象的方法和回调函数

在jsp或html页面之中我们编写一段JavaScript的脚本代码,那么可以在当前的页面当中直接编写JavaScript脚本代码。也可以使用另外一种方式:创建js文件,然后将这个js文件引入到我们所编写的jsp或者是html页面当中

示例如下:

(1)创建一个单独的JS文件,命名为AjaxRequest.js,并且在该文件中编写重构Ajax所需要的代码。

 var net = new Object();
    //创建一个全局变量net
 //编写构造函数
 net.AjaxRequest = function(url,onload,onerror,method,params){
    
     this.req = null;
    
     this.onload = onload;
    
     this.onerror = (onerror) ? onerror : this.defaultError;
    
     this.loadDate(url,method,params);

 }

 //编写用于初始化XMLHttpRequest对象并指定处理函数,最后发送HTTP请求的方法
 net.AjaxRequest.prototype.loadDate = function(url,method,params){

     if(!method){
    
         method = "GET";

     }

     if(window.XMLHttpRequest){
    
         this.req = new XMLHttpRequest();

     }
else if(window.ActiveXObject){
    
         this.req = new ActiveXObject("Microsoft.XMLHTTP");

     }

     if(this.req){

         try{
    
             var loader = this;

             this.req.onreadystatechange = function(){
    
                 net.AjaxRequest.onReadyState.call(loader);

             }
    
             this.req.open(method,url,true);
    //建立对服务器的调用
             if(method == "POST"){
                  //如果提交方式为POST
                 this.req.setRequestHeader("Content-Type",
                     "application/x-www-form-urlencoded");
   //设置请求头
             }
    
             this.req.send(params);
    //发送请求
         }
catch(err){
    
             this.onerror.call(this);

         }

     }

 
 }

 //重构回调函数
 net.AjaxRequest.onReadyState = function(){
    
     var req = this.req;
    
     var ready = req.readyState;

     if(ready == 4){
               //请求完成
         if(req.status == 200){
        //请求成功
             this.onload.call(this);

         }
else{
    
             this.onerror.call(this);

         }

     }

 }

 //重构默认的错误处理函数
 net.AjaxRequest.prototype.defaultError = function(){
    
     alert("错误数据\n\n回调状态:"+this.req.readyState+"\n状态:"+this.req.status);

 }
    

(2)在需要应用的Ajax的页面中应用一下的语句包括(1)中创建的JS文件

script language="javascript" src="AjaxRequest.js">
    /script>
    

(3)在应用Ajax的页面中编写错误处理的方法、实例化Ajax对象的方法和回调函数。

 script language="javascript">

 /*********************错误处理的方法******************/
     function onerror(){
    
         alert("您的操作有误!");

     }

 /*********************实例化Ajax对象的方法************/
     function getInfo(){
    
         var loader = new net.AjaxRequest("getInfo.jsp?nocache="+new Date().getTime(),
             deal_getInfo,onerror,"GET");

     }

 /*********************回调函数************************/
     function deal_getInfo(){
    
         document.getElementById("showInfo").innerHTML=this.req.responseText;

     }
    
 /script>
    

现在大家对于ajax重构的定义是什么,重构步骤包括哪些的内容应该都清楚了吧,希望大家阅读完这篇文章能有所收获。最后,想要了解更多ajax重构的定义是什么,重构步骤包括哪些的知识,欢迎关注网络,网络将为大家推送更多相关知识点的文章。

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

ajax

若转载请注明出处: ajax重构的定义是什么,重构步骤包括哪些
本文地址: https://pptw.com/jishu/653311.html
ajax同步异步是什么意思,怎样实现 Go语言配置高性能sql.DB实现方法步骤是什么

游客 回复需填写必要信息