AJAX 向服务器发送请求

 
创建 XMLHttpRequest 对象后,就可以向服务器发送请求了。

XMLHttpRequest 对象的 open() 方法和 send() 方法用来向服务器发送请求。

注意:AJAX 向服务器发送的是 http 请求,与我们浏览网页时发送的 http 请求一样。我们可以右键查看当前网页的源代码,由很多 HTML、CSS和JavaScript 组成,如果我们使用 AJAX 请求当前的 URL ,返回的内容是一样的。(魔芋:也就是说ajax发送的,和我们平时输入网址是一样的过程)

open() 方法(魔芋:初始化)

open() 方法用来初始化 HTTP 请求参数,但是并不发送请求。

语法:
    open(method,url,async)
参数说明:

参数 说明
method 必须参数。请求的类型,GET 或 POST。
url 必须参数。文件在服务器上的位置。
async 必须参数。是否异步发送请求,true(异步)或 false(同步)。

注意:AJAX 的强大之处在于异步请求,所以 async 一般设置为 true ,否则将失去意义。

例如,向演示文件发送一个类型为 GET 的异步请求:

  1. open("GET","/demo/javascript/ajax/ajaxDemo.php?action=getIP",true)
 

send()方法

send() 方法用来向服务器发送 HTTP 请求,并使用传递给 open() 方法的参数。

语法:
    send(string)
其中,string 为发送的内容,该参数仅仅在 POST 请求时有意义。

举例,发送一个类型为 GET 的异步请求:

  1. xmlhttp.open("GET","/demo/javascript/ajax/ajaxDemo.php?action=getIP",true);
  2. xmlhttp.send();
 

后台接收方式(PHP代码):

  1. if($_GET['action']=="getIP"){
  2. $ip=$_SERVER["REMOTE_ADDR"];// 获取 IP
  3. echo $ip;
  4. }
 

发送一个类型为 POST 的异步请求:

  1. xmlhttp.open("POST","/demo/javascript/ajax/ajaxDemo.php",true);
  2. xmlhttp.send("action=getIP");
 

后台接收方式(PHP代码):

  1. if($_POST['action']=="getIP"){
  2. $ip=$_SERVER["REMOTE_ADDR"];// 获取 IP
  3. echo $ip;
  4. }

url - 服务器上的文件

open() 方法的 url 参数是服务器上文件的地址:

  1. xmlhttp.open("GET","ajax_test.asp",true);
 

该文件可以是任何类型的文件,比如 .txt 和 .xml,或者服务器脚本文件,比如 .asp 和 .php (在传回响应之前,能够在服务器上执行任务)。

 

一个发送 AJAX 请求的完整代码:

  1. <script type="text/javascript">
  2. var xmlhttp;
  3. // 创建 XMLHttpRequest 对象
  4. try{
  5. // code for IE7+, Firefox, Chrome, Opera, Safari
  6. xmlhttp=newXMLHttpRequest();
  7. }catch(e){
  8. // code for IE6, IE5
  9. xmlhttp=newActiveXObject("Microsoft.XMLHTTP");
  10. }
  11. // 初始化请求参数
  12. xmlhttp.open("GET","/demo/javascript/ajax/ajaxDemo.php?action=getIP",true);
  13. // 发送请求
  14. xmlhttp.send();
  15. </script>
 

【03】AJAX 向服务器发送请求的更多相关文章

  1. AJAX - 向服务器发送请求请求

    AJAX - 向服务器发送请求请求 XMLHttpRequest 对象用于和服务器交换数据.直线电机生产厂家 向服务器发送请求 如需将请求发送到服务器,我们使用 XMLHttpRequest 对象的 ...

  2. AJAX向服务器发送请求

    使用 XMLHttpRequest 对象的 open() 和 send() 方法: 方法 描述 open(method,url,async) 规定请求的类型.URL 以及是否异步处理请求. metho ...

  3. Ajax学习系列——向服务器发送请求

    1.如何发送请求? 如果需要向服务器发送请求,我们使用的是XMLHttpRequest对象中的open()和send()方法. var xhr = new XMLHttpRequest();//具体创 ...

  4. ajax-向服务器发送请求

    ajax-向服务器发送请求 1.将请求发送到服务器,使用XMLHttpRequest对象的 open() 和 send() 方法.     xmlhttp. open(method,url,async ...

  5. Ajax向服务器端发送请求

    Ajax向服务器端发送请求 Ajax的应用场景 页面上拉加载更多数据 列表数据无刷新分页 表单项离开焦点数据验证 搜索框提示文字下拉列表 Ajax运行原理 Ajax 相当于浏览器发送请求与接收响应的代 ...

  6. 在向服务器发送请求时发生传输级错误。 (provider: TCP 提供程序, error: 0 - 远程主机强迫关闭了一个现有的连接。)

    用VS2005+SQLSERVER2008开发C/S的程序,程序上线运行一段时间之后发现在某些功能偶尔出现如下的错误: 在向服务器发送请求时发生传输级错误. (provider: TCP 提供程序, ...

  7. android客户端向服务器发送请求中文乱码的问

    android客户端向服务器发送请求的时候,并将参数保存到数据库时遇到了中文乱码的问题: 解决方法: url = "http://xxxx.com/Orders/saveorder.html ...

  8. System.Data.SqlClient.SqlException: 在向服务器发送请求时发生传输级错误。 (provider: TCP 提供程序, error: 0 - 远程主机强迫关闭了一个现有的连接。) .

    今天使用sql server 2008 R2管理器,进行SQL查询时,频率非常高的报错: System.Data.SqlClient.SqlException: 在向服务器发送请求时发生传输级错误. ...

  9. Ajax向服务器发起请求

    Ajax向服务器发起请求的三个步骤: 1:创建Ajax 2:打开Ajax,打开Ajax请求 3:向服务器发起请求:需要知道地址和是get请求还是post方法 向服务器发起请求的两个方法:open 和 ...

随机推荐

  1. NOI2018D2T1 屠龙勇士

    安利一下松松松的OJ: 传送门 Description: ​ 有N条巨龙, 对于每个龙含有\(a_i\)的生命, 你有N + M把砍刀, 其中M把是直接给你的, N把是杀死对应的巨龙才能获得的, 每把 ...

  2. codeforces 555B Case of Fugitive

    题目连接: http://codeforces.com/problemset/problem/555/B 题目大意: 有n个岛屿(岛屿在一列上,可以看做是线性的,用来描述岛屿位置的是起点与终点),m个 ...

  3. B - Archer

    Problem description SmallR is an archer. SmallR is taking a match of archer with Zanoes. They try to ...

  4. Service官方教程(4)两种Service的生命周期函数

    Managing the Lifecycle of a Service The lifecycle of a service is much simpler than that of an activ ...

  5. React Native for Android 学习

    前言 Facebook 在2015.9.15发布了 React Native for Android,把 JavaScript 开发技术扩展到了移动Android平台.基于React的React Na ...

  6. XML读取的小例子

    public void CalculateLeave(string userAcount, string xml) //传过来的是xml内容 { try { var xmlDoc = new Syst ...

  7. mybatis的mapper.xml文件细节

  8. vue项目中安装cnpm和node_modules

    1.安装cnpm的nodejs包管理工具,命令行: npm install -g cnpm --registry=https://registry.npm.taobao.org   2. 每个vue项 ...

  9. Vue 学习之el、template、replace和vue的生命周期 参考网址:https://segmentfault.com/a/1190000008010666

  10. iOS Programming State Restoration 状态存储

    iOS Programming State Restoration 状态存储 If iOS ever needs more memory and your application is in the ...