1⃣️先简单了解一下HTTP协议:

    http是计算机通过网络进行通信的一种规则,它是一种无状态协议(不建立持久链接,直白点儿说就是请求响应完事儿之后,链接就断开)   

 

   2⃣️一个完整的http请求有七个步骤
      1.建立TCP(传输控制协议)链接
    2.web浏览器向web服务器发送请求命令
    3.web浏览器向web服务器发送请求头信息
    4.web服务器应答
    5.web服务器发送应答头
    6.web服务器向浏览器发送数据
    7.web服务器关闭TCP链接

   3⃣️http请求由四部分组成
     1.请求方式 get/post
    (get一般用于信息的查询和获取,参数是写到url里面的,有字数限制, post一般用于服务器上信息的增删改。。发送的数据是嵌到请求体里的)

       与 POST 相比,GET 更简单也更快,并且在大部分情况下都能用。

       然而,在以下情况中,请使用 POST 请求:

  • 无法使用缓存文件(更新服务器上的文件或数据库)
  • 向服务器发送大量数据(POST 没有数据量限制)
  • 发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠

    2.请求地址url
    3.请求头(主要包含客户端的环境信息,身份验证等等)
    4.请求体(请求正文,包含客户提交的查询字符串信息、表单信息)

   4⃣️HTTP响应包含三部分内容
             1.状态码request.status(由数字和文字组成),用来显示请求成功或者失败
                  http响应 里面的状态码(由三位数字组成)有一下几种类型
                      1XX 是信息类,表示收到浏览器的请求,正在进一步处理
                      2XX 表示成功 例如 200 OK
                      3XX 重定向,表示请求没成功,客户需要进一步操作
                      4XX 客服端错误 表示客户端提交的请求有误, 例如 404 not found 在服务器端并没有找到相应的处理(动态、静态文件)
                      5XX 服务器错误,表示服务器不能完成对请求的处理(报错500)
              2.响应头(包含服务器类型、日期时间,响应内容的长短及类型等)
            3.响应体(也就是返回给客服端的数据信息) 

        服务器返回数据的两种形式

属性 描述
responseText 获得字符串形式的响应数据。
responseXML 获得 XML 形式的响应数据。

        responseText

ele.innerHTML=xhr.responseText;

        responseXML

xmlDoc=xhr.responseXML;
txt="";
x=xmlDoc.getElementsByTagName("xxx");
for (i=0;i<x.length;i++)
{
txt=txt + x[i].childNodes[0].nodeValue + "<br>";
}
document.getElementById("xxxx").innerHTML=txt;

     5⃣️ajax异步请求的过程

  ajax简介

    AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)

     AJAX 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。

    AJAX 最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容。

     AJAX 不需要任何浏览器插件,但需要用户允许JavaScript在浏览器上执行。

          

            ajax 工作原理

   

    ajax异步请求的过程

      1.实例化一个XMLHttpRequest对象(xhr对象用于和服务器交换数据)    

        XMLHttpRequest 对象的三个重要的属性:

      

         所有现代浏览器(IE7+、Firefox、Chrome、Safari 以及 Opera)均内建 XMLHttpRequest 对象。

           创建语法 var xhr=new XMLHttpRequest();

         老版本的 Internet Explorer (IE5 和 IE6)使用 ActiveX 对象:

           创建语法 var xhr=new ActiveXObject("Microsoft.XMLHTTP");

         如果需要兼容老版本浏览器的话,实际应用中可以这样写

var xhr;
if (window.XMLHttpRequest){
// IE7+, Firefox, Chrome, Opera, Safari 浏览器执行代码
xhr=new XMLHttpRequest();
}else{
// IE6, IE5 浏览器执行代码
xhr=new ActiveXObject("Microsoft.XMLHTTP");
}

    2.调用open方法

       xhr.open(method,url,true);

       method 有get 和post两种方式

   get实栗(参数要拼接到请求的链接后面)

xhr.open("GET","url?t=" + Math.random(),async);
xhr.send(null);

   post实栗(需要设置请求头,写到open和send中间,参数写道send()里)

    

xhr.open("POST","url",async);
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded; charset=utf-8”)
xhr.send("parma1=val1$parma2=val2");        

    3.调用send方法

      

      当使用 async=true 时,请规定在响应处于 onreadystatechange 事件中的就绪状态时执行的函数:

      通过 AJAX,JavaScript 无需等待服务器的响应,而是:

  • 在等待服务器响应时执行其他脚本
  • 当响应就绪后对响应进行处理
xhr.onreadystatechange=function(){
if(xhr.status==200) {
if (xhr.readyState==4) {
ele.innerHTML=xhr.responseText;
}
}
}
xhr.open("GET","url",true);
xhr.send();

    如需使用 async=false,请将 open() 方法中的第三个参数改为 false:
    不推荐使用 async=false,但是对于一些小型的请求,也是可以的。
    此时,JavaScript 会等到服务器响应就绪才继续执行。如果服务器繁忙或缓慢,应用程序会挂起或停止。

xhr.open("GET",url,false);
xhr.send();
ele.innerHTML=ele.responseText;

4.对readystate进行监听
               readystate
                   =0 UNSENT (未打开) open()方法还未被调用
                   =1 OPENED (未发送) send()方法还未被调用
                   =2 HEADERS_RECEIVED (已获取响应头) send()方法已经被调用, 响应头和响应状态已经返回
                   =3 LOADING (正在下载响应体) 响应体下载中; responseText中已经获取了部分数据
                   =4 DONE (请求完成) 整个请求过程已经完毕

        当请求被发送到服务器时,我们需要执行一些基于响应的任务。
        每当 readyState 改变时,就会触发 onreadystatechange 事件。
        readyState 属性存有 XMLHttpRequest 的状态信息。

xhr.onreadystatechange=function(){
if(xhr.status==200) {
if (xhr.readyState==4) {
ele.innerHTML=xhr.responseText;
}
}
}

如果有多个ajax任务,我们可以这样做:

封装ajax请求代码

function loadContent(url,fn){
  if (window.XMLHttpRequest){

    // IE7+, Firefox, Chrome, Opera, Safari 代码
    xhr = new XMLHttpRequest();
  }else{

    // IE6, IE5 代码
    xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");

  }

  xhr.open("GET",url,true);
  xhr.send();
  xhr.onreadystatechange=fn;
}

具体事件(比如说某元素的点击事件触发ajax请求)
Btn.onclick = function(){
  loadContent(url,function(){
    if(xhr.status == 200) {
      if(xhr.readyState == 4) {
        ele.innerHTML = xhr.responseText;
      }
    }
  })
}

 综合实栗

当用户在输入框中键入字符时,会执行函数 "showHint()" 。该函数由 "onkeyup" 事件触发:

前端代码

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script>
function showHint(str)
{
var xmlhttp;
if (str.length==0)
{
document.getElementById("txtHint").innerHTML="";
return;
}
if (window.XMLHttpRequest)
{
// IE7+, Firefox, Chrome, Opera, Safari 浏览器执行代码
xmlhttp=new XMLHttpRequest();
}
else
{
// IE6, IE5 浏览器执行代码
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200) //4描述一种"已加载"状态;此时,响应已经被完全接收。 //200表示成功收到
{
document.getElementById("txtHint").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","path/xx/xx.php?q="+str,true);
xmlhttp.send();
}
</script>
</head>
<body> <h3>在输入框中尝试输入字母 a:</h3>
<form action="">
输入姓名: <input type="text" id="txt1" onkeyup="showHint(this.value)" />
</form>
<p>提示信息: <span id="txtHint"></span></p> </body>
</html>

后台(PHP)代码

<?php
// Fill up array with names
$a[]="Anna";
$a[]="Brittany";
$a[]="Cinderella";
$a[]="Diana";
$a[]="Eva";
$a[]="Fiona";
$a[]="Gunda";
$a[]="Hege";
$a[]="Inga";
$a[]="Johanna";
$a[]="Kitty";
$a[]="Linda";
$a[]="Nina";
$a[]="Ophelia";
$a[]="Petunia";
$a[]="Amanda";
$a[]="Raquel";
$a[]="Cindy";
$a[]="Doris";
$a[]="Eve";
$a[]="Evita";
$a[]="Sunniva";
$a[]="Tove";
$a[]="Unni";
$a[]="Violet";
$a[]="Liza";
$a[]="Elizabeth";
$a[]="Ellen";
$a[]="Wenche";
$a[]="Vicky"; //get the q parameter from URL
$q=$_GET["q"]; //lookup all hints from array if length of q>0
if (strlen($q) > 0){
$hint="";
for($i=0; $i<count($a); $i++) {
if (strtolower($q)==strtolower(substr($a[$i],0,strlen($q)))) {
if ($hint=="") {
$hint=$a[$i];
} else {
$hint=$hint." , ".$a[$i];
}
}
}
} // Set output to "no suggestion" if no hint were found
// or to the correct values
if ($hint == ""){
$response="no suggestion";
}else{
$response=$hint;
} //output the response
echo $response;
?>

希望我整理的内容(个人理解+部分copy)可以帮到大家,如果有什么不足的地方还望大家批评指正,再此先谢过了!!!

原生ajax实现http请求的更多相关文章

  1. 原生Ajax GET+POST请求无刷新实现文本框用户名是否被注册

    实现Ajax需要使用一个核心对象XMLHttpRequest XMLHttpRequest对象可以在不向服务器提交整个页面的情况下,实现局部更新网页.当页面全部加载完毕后,客户端通过该对象向服务器请求 ...

  2. 手动(原生ajax)和自动发送ajax请求 伪ajax(Ifrname)

    自动发送  ---> 依赖jQuery文件 实例-->GET请求: function AjaxSubmit() { $.ajax({ url:'/data', type:"GET ...

  3. 原生ajax中get和post请求

    后台代码: class AjaxHanlder(tornado.web.RequestHandler): def get(self): print(self.get_argument('type',N ...

  4. 原生AJAX请求教程

    ajax 即 Asynchronous Javascript And XML,AJAX 不是一门的新的语言,而是对现有持术的综合利用.本质是在 HTTP 协议的基础上以异步的方式与服务器进行通信. 异 ...

  5. 原生JS实现ajax 发送post请求

    1. [代码]原生JS实现ajax 发送post请求 <script> var oStr = ''; var postData = {}; var oAjax = null; //post ...

  6. 原生ajax的请求过程

    原生ajax的请求过程 创建全平台兼容的XMLHttpRequest对象: function getXHR(){ var xhr = null; if(window.XMLHttpRequest) { ...

  7. Servlet处理原生Ajax请求

    萌新小白人生中的第一篇博客,难免会有差错,还望各位大佬多多包涵. 1. Ajax技术简介      Ajax(Asynchronous JavaScript and XML,异步JavaScript和 ...

  8. 原生 ajax 请求

    ajax 即 Asynchronous Javascript And XML,AJAX 不是一门的新的语言,而是对现有持术的综合利用.本质是在 HTTP 协议的基础上以异步的方式与服务器进行通信. 异 ...

  9. js 原生ajax请求

    什么是ajax 所有现代浏览器均支持 XMLHttpRequest 对象(IE5 和 IE6 使用 ActiveXObject). XMLHttpRequest 用于在后台与服务器交换数据.这意味着可 ...

随机推荐

  1. Greenplum 简单性能测试与分析

    如今,多样的交易模式以及大众消费观念的改变使得数据库应用领域不断扩大,现代的大型分布式应用系统的数据膨胀也对数据库的海量数据处理能力和并行处理能力提出了更高的要求,如何在数据呈现海量扩张的同时提高处理 ...

  2. Android中的WebView实战详解(二)

    四.如何用WebView下载软件? 四.如何用WebView下载软件? public class MainActivity extends AppCompatActivity { private We ...

  3. hdoj1016 [dfs]

    http://acm.hdu.edu.cn/showproblem.php?pid=1016 题意: 已知一个数n,在1-n(包含 n ,0 < n < 20)里组合形成一个环形,使得每两 ...

  4. Android使用Aspectj

    使用AspectJ 集成步骤: 1.AS配置Aspectj环境 2.配置使用ajc编译 4.定义注解 5.配置规则 6.使用 7.注意事项 AS配置Aspectj环境.Aspect目前最新版本为 1. ...

  5. Java程序员应当知道的10个面向对象设计原则

    面向对象设计原则是OOPS编程的核心, 但我见过的大多数Java程序员热心于像Singleton (单例) . Decorator(装饰器).Observer(观察者) 等设计模式,而没有把足够多的注 ...

  6. Entity Framework 新手入门友好实例

    起因 因为实习的原因,程序之中用到了较多的数据库操作逻辑.如果每一处数据库操作都手写的话,工作量较大且后期不易于维护,所以希望能通过 ORM 框架来解决这两个问题. 在昨天之前,对于 ORM 这个词汇 ...

  7. 读书笔记 effective c++ Item 37 永远不要重新定义继承而来的函数默认参数值

    从一开始就让我们简化这次的讨论.你有两类你能够继承的函数:虚函数和非虚函数.然而,重新定义一个非虚函数总是错误的(Item 36),所以我们可以安全的把这个条款的讨论限定在继承带默认参数值的虚函数上. ...

  8. flex中创建弹出窗口,并传值

    在flex页面中首先创建一个弹出窗口,代码如下: <?xml version="1.0" encoding="utf-8"?> <s:Titl ...

  9. css——样式表分类,选择器

    一,样式表分类 (1)内联样式[优先级最高][常用][代码重复使用性最差] (当特殊的样式需要应用到个别元素时,就可以使用内联样式. 使用内联样式的方法是在相关的标签中使用样式属性.样式属性可以包含任 ...

  10. JSON与JAVA的数据转换

    http://developer.51cto.com/art/200906/129090.htm java.lang.ClassNotFoundException: net.sf.json.JSONA ...