Ajax 学习 - 基础学习

《AJax - Async Javascript and xml - 异步的JavaScript和XML》

一、基础认识

AJax技术的目的:实现页面无刷新数据动态更改

优点: 

  + 不需要插件支持

  + 提供WEB程序的功能

  + 优秀的用户体验

  + 减轻服务器带宽的负担

缺点:

  + 破坏浏览器的前进与后退

  + 搜索引擎SEO的支持性不好

 

二、代码示例

学习后编写的一个很基础的Ajax函数,帮助自己更好的掌握Ajax

/** method => Ajax请求所采用的方法,GET或POST * URL => 所要请求页面的URL* paras=> 发送时附加的参数* callback => 完成请求或页面数据准备完毕时执行的方法 
*/function Ajax(method,url,paras,callback){function getXMLHttpReq(){var XMLHttpReq = null;if(window.XMLHttpRequest){ XMLHttpReq = new XMLHttpRequest();}else if(window.ActiveXObject){XMLHttpReq = new ActiveXObject('Microsoft.XMLHTTP');}return XMLHttpReq;}xhr = getXMLHttpReq();if(method ==='POST'){xhr.open('POST',url,true);  xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');if(paras!=''){xhr.send(paras);}else{xhr.send(null);}}else{if(paras!=''){url = encodeURI(url+'?'+paras);    }xhr.open('GET',url,true);xhr.send(null);}xhr.onreadystatechange=function(){if(xhr.readyState==4&&xhr.status==200){callback();}}
}//调用方法function Ajax1(){Ajax('GET','test.php','',function(){document.getElementById('responseText').innerHTML = xhr.responseText;})            }

 

· 代码说明:

ActiveXObject  //  利用ActiveX插件可以与微软的其它组件进行交换,包括这里我需要的微软自带的HTTP请求方法。new ActiveXObjcet('Microsoft.XMLHTTP') // IE5/6支持的HTTP请求方法
xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded'); 
//如果Ajax请求是通过POST方式,那么为了方便后台通过键值对的形式获取数据,可以指定数据的发送以表单的形式。
open('GET','index.php?a=1&b=2',true)  //GET方式,通过在URL附加参数进行数据的传输。

XMLHttpReq.send(pars)  //POST方式的数据发送
url = encodeURI(url+'?'+pars);     
//为了解决IE6/7在GET方式下传输中文参数出现乱码的情况,会在参数传输之前利用JS进行URL编码。

echo urldecode($_GET['a']) 
// 客户端进行编码,服务端进行解码

 

· 重点讲解:

  1. readyState && status

   readyState表示HTTP请求的运行状态,不论请求的数据是否找到,都会经历以下的过程:

    0 ----  请求未初始化

    1 ----  与服务器建立连接

    2 ---- 请求已经接收

           3 ---- 请求正在处理

   status 则表示了HTTP所请求数据的状态[常见的反馈码]:

    200 ---- 数据请求完成,已经可以使用。

    404 ---- 页面未找到。

  2. open()

    功能:初始化请求的参数。

    格式:open('请求数据的方式','所要请求的页面URL','是否异步');

    格式说明:

         · 请求数据的方式:GET | POST

         ·  是否异步:true(异步) | false(同步)

    * 如果存在setRequestHeader()方法,一定要把open()方法放在它之前的一行。

 

  3. send()

    功能:发送请求。

    格式:send(paras)

    代码示例:

send(null)//在GET方式下用这种方式,因为参数会附加在URL后进行传输。
 
send('fname=神&lname=经病') //在POST方式,用这种方式传输参数,但要记得使用setRequestHeader()方法

  

  4. 同步与异步

    xmlHttpReq对象的open()方法第三个参数可以设置同步或异步的方式。

    true - 表示为异步,它不会等待服务器的执行完成。

    false - 表示同步,它会等待服务器执行完成,否则便会挂起程序,一直等待,一般不推荐是用同步的方式,不过对于一些小程序还是可以使用的。

  

  5.  setRequestHeader()

     该方法可以设置请求的头部信息,常用以post方式向一个动态网页文件提交数据时使用。这

    是因为PHP中的$_POST['key']方法,需要用到键值对的格式,因此必须声明请求的类型为: setRequestHeader('Content-Type','application/x-www-form-urlencoded') 以表单提交数据的方式来发送数据到服务器。

    

  6. 使用时间戳或随机数来确保无缓存的请求数据

    

//时间戳
open('GET','index.php?t='+ new Date()*1,true)//随机数
open('GET','index.php?m='+ Math.random(),true)

 

转载于:https://www.cnblogs.com/HCJJ/p/4869732.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/374367.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

STM32F1笔记(十三)SPI

SPI:Serial Peripheral interface,串行外围设备接口。 SPI接口一般使用4条线通信: MISO主设备数据输入,从设备数据输出。 MOSI主设备数据输出,从设备数据输入。 SCLK时钟信号,由主设备产生。 从图中可以…

红帽Openshift:入门–云中的Java EE6

现在有一段时间,我正在研究“云”。 研究它的功能,它可以做什么,为什么我们应该切换到“云”,进行讨论,与RealDolmen的云专家maartenballiauw等人交谈。 我已经在Google App Engine(用于Java)上…

python自定义函数参数_python自定义函数的参数之四种表现形式

(1)def a(x,y):print x,y 这是最常见的定义方式,调用该函数,a(1,2)则x取1,y取2,形参与实参相对应,如果a(1)或者a(1,2,3)则会报错 (2)def a(x,y3):print x,y 提供了默认值…

osg添加纹理示例

转自http://www.cnblogs.com/ylwn817/articles/1976851.html #include <osgDB/ReadFile>#include <osgViewer/Viewer> #include <osg/Node>#include <osg/Geode>#include <osg/Geometry>#include <osg/Group>#include <osg/Texture2D&g…

2.运算符

Swift 支持大部分标准 C 语言的运算符&#xff0c;分为一元、二元和三元运算符。 一元运算符对单一操作对象操作&#xff08;如 -a&#xff09;。一元运算符分前置运算符和后置运算符&#xff0c;前置运算符需紧跟在操作对象之前&#xff08;如 !b&#xff09;&#xff0c;后置…

C语言开发笔记(二)volatile

volatile常用于多线程共享资源和嵌入式软件的中断。 &#xff08;一&#xff09;嵌入式软件中断中volatile的应用 volatile unsigned short g_timer3_count 0;void TIM3_IRQHandler(void) {if (TIM_GetITStatus(TIM3, TIM_IT_Update) ! RESET){TIM_ClearITPendingBit(TIM3, T…

在WebLogic 12c上运行RichFaces 4.1.0.Final

您可能已经注意到&#xff0c;我只是喜欢JSF。 不仅是Mojarra的规范和参考实现&#xff0c;而且是市场上最具创意的组件套件。 这是我一直以来最喜欢的PrimeFaces &#xff0c;当然还有RichFaces 。 这就是为什么在这里找到“在xxx上运行xxx”帖子的原因:)今天是我的RichFaces和…

maven 私服的setting.xml配置

1 <?xml version"1.0" encoding"UTF-8"?>2 <settings xmlns"http://maven.apache.org/SETTINGS/1.0.0" 3 xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance" 4 xsi:schemaLocation"http://m…

python中的运算符_Python 中的神秘运算符

今天我们来讲讲 Python 里一个不为众人所知的运算符。你可能会觉得疑惑&#xff1a;还有我不知道的运算符&#xff1f;别急着下结论&#xff0c;先往下看看再说。 在 Python3.5 中通过 PEP465https://www.python.org/dev/peps/pep-0465 加入了 运算符&#xff0c;也就是矩阵相乘…

input type:text输入框点击输入,文字消失

<input name"Header1$txbsearch" type"text" value"18912345678" id"Header1_txbsearch" class"txbindex" οnfοcus"if (value 18912345678){value }" οnblur"if (value ){value18912345678}" sty…

C语言开发笔记(一)自动转换和强制转换

整型数据和实行数据之间可以进行运算&#xff0c;而且字符型数据可以和整型数据通用&#xff0c;所以整型、实型、字符型数据之间也是可以进行运算的&#xff0c;但在运算处理之前&#xff0c;不同类型的数据要事先转换成同一种数据类型。转换方法有两种&#xff1a;自动转换和…

Apache Shiro:简化应用程序安全性

考虑到JAVA已有10多年的历史了&#xff0c;对于需要在其应用程序中内置身份验证和授权的应用程序开发人员来说&#xff0c;选择的数量非常少。 在JAVA和J2EE中&#xff0c;JAAS规范是一种尝试解决安全性的问题。 尽管JAAS用于身份验证&#xff0c;但授权部分却过于繁琐而无法使…

Maven 导出依赖Jar,生成source.jar,javadoc.jar

下载最新版的Maven http://maven.apache.org/download.cgi 解压到本地文件夹新建环境变量 MAVEN_HOME maven解压目录在path加入 %MAVEN_HOME%/bin;需要确保已经有Java环境变量 &#xff08;打开cmd java -version,javac -version两个命令看正常不&#xff09;一、导出到默认目…

python提取包含特定字符串的行_python语言----txt中搜索特定字符串所在行

打开IDLE(python)&#xff0c;并新创建一个py文件&#xff0c;编辑内容为&#xff1a; 本示例演示如何在一个txt文件中搜索特定的字符串&#xff0c;并将其行显示# 1. 打开文件# 2. 读取行信息# 3. 判断是否包含关键词# 4. 不包含则循环操作&#xff0c;包含的话将行显示并退出…

asp.net 分布式应用开发

Net Framework推出的许多新技术为上述任务的实现提供了相对简单的解决方案。其中&#xff0c;基于SOAP的Web Service在处理分布式应用时具有比传统的DCOM/CORBA明显的优点&#xff0c;结合基于Web的ASP.NET页面开发技术和SQL Server数据存储技术&#xff08;或Xml文档&#xff…

Spring Data JPA的持久层

1.概述 本文将重点介绍Spring 3.1&#xff0c;JPA和Spring Data的持久层的配置和实现。 有关使用基于Java的配置和项目的基本Maven pom设置Spring上下文的分步介绍&#xff0c;请参阅本文 。 持久性与春天 系列 &#xff1a; 第1部分 – 具有Spring 3.1和Hibernate的持久层 …

C语言开发笔记(三)自加和自减

看到一段代码&#xff0c;被坑了。 #include <stdio.h>int main(void) {int a 7;printf("%d\n", a);printf("%d\n", a--);printf("%d\n", -a);printf("%d\n", -a--);printf("%d\n", a);return 0; } 结果为 -a的逻辑…

求解数独回溯算法

实现的java代码如下&#xff08;该算法只是将结果打印输出&#xff0c;并没有对原数组实现更改&#xff09;&#xff1a; //判断a[i][j]取值val是否有效public boolean isValid(int[][] a, int i, int j, int val){//判断是否跟同行冲突for(int j10;j1<9;j1){if(a[i][j1]val…

python语言属于哪一种语言_Python与Java:你应该学习哪种语言,他们有什么区别?...

在企业招聘中&#xff0c; Python和Java经常是需求最大的编程语言。这两种编程功能强大&#xff0c;灵活且面向对象的语言&#xff0c;通常在组织中和各种其他设置中使用。这可能会导致我们提出一个不可避免的问题&#xff1a;哪个更好&#xff1f; 这是一个复杂的问题&#xf…

关于手机端CSS Sprite图标定位的一些领悟

今天在某个群里面闲逛&#xff0c;看见一个童鞋分享了一个携程的移动端的页面。地址这里我也分享下吧&#xff1a;http://m.ctrip.com/html5/在手机端我都很少用雪碧图合并定位图标&#xff0c;用的比较多就是用字体图标来代替&#xff0c;有些图标不多的时候就自己单个的切出来…