好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > php下的原生ajax請求用法實例分析

php下的原生ajax請求用法實例分析

熱門標簽:百應電話機器人服務 岳陽外呼型呼叫中心系統在哪里 騰訊外呼管理系統 揚州地圖標注app 青島語音外呼系統招商 昭通辦理400電話 山西回撥外呼系統 山西探意電話機器人 河南電銷卡外呼系統哪家強

本文實例講述了php下的原生ajax請求用法。分享給大家供大家參考,具體如下:

瀏覽器中為我們提供了一個JS對象XMLHttpRequet,它可以幫助我們發送HTTP請求,并接受服務端的響應。

意味著我們的瀏覽器不提交,通過JS就可以請求服務器。 

ajax(Asynchronous Javascript And XML)其實就是通過XHR對象,執行HTTP請求。  

1、創建XHR對象

var xhr = new XMLHttpRequest(); //暫不考慮兼容

2、XHR的對象屬性和方法

方法:
open("get/post", url, true/false);
//有參數則k=vk1=v1這種形式
send(null);

屬性:
//代表請求狀態,不斷變化,為4時,請求結束
readyState
//響應的內容
responseText
//響應的狀態碼200,403,404
status
//狀態文字
statusText

事件:
//當readyState變化時會觸發此事件
onreadystatechange = function() {};

3、通過XHR對象發送get請求

!DOCTYPE html>
html>
  head>
    title>ajax/title>
    meta charset="UTF-8">
    meta name="viewport" content="width=device-width, initial-scale=1.0">
  /head>
  body>
    div id="box">
      input type="text" name="con" value="" id="con" />
    /div>
  /body>
  script type="text/javascript">
    var ipt = document.getElementById("con");

    ipt.onblur = function () {
      var con = this.value;
      //創建XHR對象
      var xhr = new XMLHttpRequest();
      //設置請求URL
      var url = "./ajax.php?con=" + con;
      //設置XHR對象readyState變化時響應函數
      xhr.onreadystatechange = function () {
        //readyState是請求的狀態,為4表示請求結束
        if (xhr.readyState == 4) {
          //responseText服務器響應的內容
          alert("服務器響應數據:" + this.responseText);
        }
      };
      //打開鏈接
      xhr.open("get", url, true);
      //發送請求
      xhr.send(null);
    }
  /script>
/html>

ajax.php如下:

?php
$con = !empty($_GET['con']) ? trim($_GET['con']) : '沒有數據';
echo $con;

填入數據,當鼠標焦點離開input時,觸發請求,彈出響應內容。  

4、通過XHR對象發送post請求

(1)、open()第1參數為post

(2)、POST的參數以k=vk1=v1k2=v2的形式拼接,并用send()發送

(3)、必須要設置Content-Type為application/x-www-form-urlencoded

!DOCTYPE html>
html>
  head>
    title>ajax/title>
    meta charset="UTF-8">
    meta name="viewport" content="width=device-width, initial-scale=1.0">
  /head>
  body>
    div id="box">
      input type="text" name="name" value="" id="name" />
      input type="password" name="pwd" value="" id="pwd" />
      input type="submit" name="sub" value="提交" id="sub" />
    /div>
  /body>
  script type="text/javascript">
    var sub = document.getElementById("sub");

    sub.onclick = function () {
      var name = document.getElementById("name").value;
      var pwd = document.getElementById("pwd").value;
      //創建XHR對象
      var xhr = new XMLHttpRequest();
      //設置請求URL
      var url = "./ajax.php";
      //設置XHR對象readyState變化時響應函數
      xhr.onreadystatechange = function () {
        //readyState是請求的狀態,為4表示請求結束
        if (xhr.readyState == 4) {
          //responseText服務器響應的內容
          alert("服務器響應數據:" + this.responseText);
        }
      };
      //打開鏈接
      xhr.open("post", url, true);
      //設置請求頭部
      xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
      //發送請求
      xhr.send("name=" + name + "pwd=" + pwd);
    }

  /script>
/html>

ajax.php如下:

?php
$name = !empty($_POST['name']) ? trim($_POST['name']) : '沒有數據';
$pwd = !empty($_POST['pwd']) ? trim($_POST['pwd']) : '沒有數據';
echo '用戶名:', $name, '密碼:', $pwd;

單擊submit后發送post請求,彈出響應信息。  

5、返回值json,html,text,xml

返回值只有兩種text,和xml。不過text內容中可以是一段html或json結構的字符串。  

(1)、返回json格式

!DOCTYPE html>
html>
  head>
    title>ajax/title>
    meta charset="UTF-8">
    meta name="viewport" content="width=device-width, initial-scale=1.0">
  /head>
  body>
    div id="box">
      select id="city">/select>
      input type="button" value="獲取" id="get" />
    /div>
  /body>
  script type="text/javascript">
    var get = document.getElementById("get");
    var city = document.getElementById("city");

    get.onclick = function () {
      //創建XHR對象
      var xhr = new XMLHttpRequest();
      //設置請求URL
      var url = "./ajax.php";
      //設置XHR對象readyState變化時響應函數
      xhr.onreadystatechange = function () {
        //readyState是請求的狀態,為4表示請求結束
        if (xhr.readyState == 4) {
          //responseText服務器響應的內容
          //通過eval把傳來的json字符串轉成對象
          var data = eval(this.responseText);
          var str = "";
          for(var ix in data) {
            str += "option value='" + data[ix].id + "'>" + data[ix].name + "/option>";
          }
          city.innerHTML = str;
        }
      };
      //打開鏈接
      xhr.open("get", url, true);
      //發送請求
      xhr.send(null);
    }
  /script>
/html>

ajax.php如下:

?php
$data = array(
  array('id' => 1, 'name' => '上海'),
  array('id' => 2, 'name' => '北京'),
  array('id' => 3, 'name' => '深圳'),
);
echo json_encode($data);

(2)、返回xml格式

xml通過responseXML來讀取,responseXML不是字符串,是DOM對象。

!DOCTYPE html>
html>
  head>
    title>ajax/title>
    meta charset="UTF-8">
    meta name="viewport" content="width=device-width, initial-scale=1.0">
  /head>
  body>
    div id="box">
      div id="news">/div>
      input type="button" value="獲取" id="get" />
    /div>
  /body>
  script type="text/javascript">
    var get = document.getElementById("get");
    var news = document.getElementById("news");

    get.onclick = function () {
      //創建XHR對象
      var xhr = new XMLHttpRequest();
      //設置請求URL
      var url = "./ajax.php";
      //設置XHR對象readyState變化時響應函數
      xhr.onreadystatechange = function () {
        //readyState是請求的狀態,為4表示請求結束
        if (xhr.readyState == 4) {
          //responseXML服務器響應的內容
          var data = this.responseXML;
          var str = "";
          var title = data.getElementsByTagName("title");
          str += "p>" + title[0].childNodes[0].nodeValue + "/p>";
          str += "p>" + title[1].childNodes[0].nodeValue + "/p>";
          str += "p>" + title[2].childNodes[0].nodeValue + "/p>";
          news.innerHTML = str;
        }
      };
      //打開鏈接
      xhr.open("get", url, true);
      //發送請求
      xhr.send(null);
    }
  /script>
/html>

ajax.php如下:

?php
header('Content-Type: text/xml;charset=utf-8');
$xml = EOD
?xml version="1.0" encoding="utf-8"?>
news>
  title>111/title>
  title>222/title>
  title>333/title>
/news>
EOD;
echo $xml;

6、ajax的同步與異步

通過設置open()的第三個參數true/false,來查看請求的效果。  

同步請求:

發送請求->等待結果->操作完成->繼續后面代碼。我們必須等待結果處理完畢后才能繼續后面的代碼,嚴格按照步驟一步一步執行。  

異步請求:

發送請求->繼續后面代碼->響應結果接收完畢->操作結果。異步請求在發送請求之后沒有等待結果的返回而是繼續執行后面的代碼,也就是說在結果返回之前用戶可以操作其他東西。

更多關于PHP相關內容可查看本站專題:《PHP+ajax技巧與應用小結》、《PHP網絡編程技巧總結》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家PHP程序設計有所幫助。

您可能感興趣的文章:
  • php中如何判斷一個網頁請求是ajax請求還是普通請求
  • html+js+php一次原始的Ajax請求示例
  • PHP處理Ajax請求與Ajax跨域問題
  • php判斷是否為ajax請求的方法
  • jQuery通過ajax請求php遍歷json數組到table中的代碼(推薦)
  • Ajax請求PHP后臺接口返回信息的實例代碼
  • PHP開發框架kohana中處理ajax請求的例子
  • php檢查是否是ajax請求的方法
  • 在php中判斷一個請求是ajax請求還是普通請求的方法
  • 原生javascript的ajax請求及后臺PHP響應操作示例

標簽:寶雞 南陽 湛江 婁底 黃南 宜賓 鎮江 銅川

巨人網絡通訊聲明:本文標題《php下的原生ajax請求用法實例分析》,本文關鍵詞  php,下,的,原生,ajax,請求,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《php下的原生ajax請求用法實例分析》相關的同類信息!
  • 本頁收集關于php下的原生ajax請求用法實例分析的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 亚洲色图偷| 亚洲精品国产成人片在线观看一区二区三区| 超级巨大乳孔小说| 久久九九有精品国产23百花影院| 韩国公妇理伦片免费观看| 精品乱码一区二区在线观看| 成本人3d动漫视频在线看| 国产福利网| 国产美女一级A片免费 | 韩国中文三级HD字幕| chinese正装黑袜gay踩奴| 男女XXOO做爰猛烈动图片漫画| 新婚之夜乱肉肉全文| 草莓视频一区二区精品| 爽?躁多水?快?叫爽| 色屁屁WWW影院免费观看入口| 非洲黑妞xxx×hd精品| 女王的脚奴视频vk| 女人自己扒荫道口视频| 激情五月综合色婷婷一区二区| 国产成人国产在线观看入口| 丁香啪啪综合成人亚洲小说| 性8se春暖花开旧版入口| 在车上被弄到高c| 中文一级片| 扒开内裤边吃奶XXOO视频| 丰满大肥奶肥婆BBBwww| 性中国videosfreehd| 一品村夫| 欧美性夜黄A片爽爽免费视频| 女人下面湿得快说明什么| 国产xxx免费观看| 精品黑人一区二区三区久久| 成人毛片手机版免费看| 肚兜藏不住两团雪白 军营| 少妇一边喂奶一边我做 | 97精品一区二区三区在线不卡| 我和漂亮麻麻的婬乱生活状态| 精品动漫3D一区二区三区免费版 | 91精品久久久久久久| 3个男人躁我一个爽|