项目积累--ajax.js封装

js 代码
 
  1. //ajax封装  
  2.   
  3. var req;   
  4. var xmlDoc,xmlHttpRequest;  
  5. var ajaxExcetpion;  
  6. ///调用的URL(以GET方式组装的参数),回调方法callback  
  7. ///返回:成功返回true,失败返回false;  
  8. function ajaxCallByGet(url,callback,win_self)  
  9. {  
  10. if (window.XMLHttpRequest) {  
  11.                 win_self.req = new XMLHttpRequest();  
  12.                     if (req.overrideMimeType){  
  13.                     req.overrideMimeType('text/xml');  
  14.                         }     
  15.          } else if (window.ActiveXObject) {  
  16.             if (xmlHttpRequest) {  
  17.               win_self.req= new ActiveXObject(xmlHttpRequest);  
  18.             }else {  
  19.                    var versions = ["Msxml2.XMLHTTP.7.0""Msxml2.XMLHTTP.6.0""Msxml2.XMLHTTP.5.0""Msxml2.XMLHTTP.4.0""MSXML2.XMLHTTP.3.0""MSXML2.XMLHTTP","MSXML.XMLHTTP",  
  20.                         "Microsoft.XMLHTTP"];  
  21.                for (var i = 0; i < versions.length ; i++) {  
  22.                  try {  
  23.                      win_self.req = new ActiveXObject(versions[i]);  
  24.                      if (win_self.req) {  
  25.                         xmlHttpRequest = versions[i];  
  26.                         ajaxExcetpion = null;  
  27.                         break;  
  28.                     }  
  29.                 }  
  30.                 catch (objException) {  
  31.                     ajaxExcetpion = objException;  
  32.                 } ;  
  33.             }  
  34.             ;  
  35.         }  
  36.     }  
  37.       
  38.     if(ajaxExcetpion){  
  39.       return false;       
  40.     }  
  41.     if(req){   
  42.                       
  43.          req.open("GET", url, true);   
  44.          req.onreadystatechange = callback;   
  45.          req.send(null);   
  46.     }  
  47.      return true;  
  48. }  
  49.   
  50.   
  51. /* 
  52.  * Returns an new XMLHttpRequest object, or false if the browser 
  53.  * doesn't support it 
  54.  */  
  55. function newXMLHttpRequest() {  
  56.   
  57.     var xmlreq = false;  
  58.       
  59.     if (window.XMLHttpRequest) {  
  60.         xmlreq = new XMLHttpRequest();  
  61.         if (xmlreq.overrideMimeType){  
  62.             xmlreq.overrideMimeType('text/xml');  
  63.         }     
  64.     } else if (window.ActiveXObject) {  
  65.         if (xmlHttpRequest) {  
  66.             xmlreq= new ActiveXObject(xmlHttpRequest);  
  67.         }else {  
  68.             var versions = ["MSXML.XMLHTTP",  
  69.                         "Microsoft.XMLHTTP","Msxml2.XMLHTTP.7.0""Msxml2.XMLHTTP.6.0""Msxml2.XMLHTTP.5.0""Msxml2.XMLHTTP.4.0""MSXML2.XMLHTTP.3.0""MSXML2.XMLHTTP"];  
  70.             for (var i = 0; i < versions.length ; i++) {  
  71.                 try {  
  72.                     xmlreq = new ActiveXObject(versions[i]);  
  73.                     if (xmlreq) {  
  74.                         xmlHttpRequest = versions[i];  
  75.                         ajaxExcetpion = null;  
  76.                         break;  
  77.                     }  
  78.                 }  
  79.                 catch (objException) {  
  80.                     ajaxExcetpion = objException;  
  81.                 }   
  82.                   
  83.             }  
  84.               
  85.         }  
  86.     }  
  87.   
  88. return xmlreq;  
  89. }  
  90.   
  91.   
  92.     /* 
  93.     * Returns a function that waits for the specified XMLHttpRequest 
  94.     * to complete, then passes it XML response to the given handler function. 
  95.   * req - The XMLHttpRequest whose state is changing 
  96.   * responseXmlHandler - Function to pass the XML response to 
  97.   */  
  98.  function getReadyStateHandler(req, responseXmlHandler) {  
  99.   
  100.    // Return an anonymous function that listens to the XMLHttpRequest instance  
  101.    return function () {  
  102.   
  103.      // If the request's status is "complete"  
  104.      if (req.readyState == 4) {  
  105.          
  106.        // Check that we received a successful response from the server  
  107.        if (req.status == 200) {  
  108.   
  109.          // Pass the XML payload of the response to the handler function.  
  110.          responseXmlHandler(req);  
  111.   
  112.        } else {  
  113.   
  114.          // An HTTP problem has occurred  
  115.          alert("HTTP error "+req.status+": "+req.statusText);  
  116.        }  
  117.      }  
  118.    }  
  119.  }  
  120.   
  121.   
  122. function test()  
  123. {   
  124.   alert("test");  
  125. }  
内容概要:本文详细介绍了基于FPGA的144输出通道可切换电压源系统的设计与实现,涵盖系统总体架构、FPGA硬件设计、上位机软件设计以及系统集成方案。系统由上位机控制软件(PC端)、FPGA控制核心和高压输出模块(144通道)三部分组成。FPGA硬件设计部分详细描述了Verilog代码实现,包括PWM生成模块、UART通信模块和温度监控模块。硬件设计说明中提及了FPGA选型、PWM生成方式、通信接口、高压输出模块和保护电路的设计要点。上位机软件采用Python编写,实现了设备连接、命令发送、序列控制等功能,并提供了一个图形用户界面(GUI)用于方便的操作和配置。 适合人群:具备一定硬件设计和编程基础的电子工程师、FPGA开发者及科研人员。 使用场景及目标:①适用于需要精确控制多通道电压输出的实验环境或工业应用场景;②帮助用户理解和掌握FPGA在复杂控制系统中的应用,包括PWM控制、UART通信及多通道信号处理;③为研究人员提供一个可扩展的平台,用于测试和验证不同的电压源控制算法和策略。 阅读建议:由于涉及硬件和软件两方面的内容,建议读者先熟悉FPGA基础知识和Verilog语言,同时具备一定的Python编程经验。在阅读过程中,应结合硬件电路图和代码注释,逐步理解系统的各个组成部分及其相互关系。此外,实际动手搭建和调试该系统将有助于加深对整个设计的理解。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值