主頁(yè) > 知識(shí)庫(kù) > php下的原生ajax請(qǐng)求用法實(shí)例分析

php下的原生ajax請(qǐng)求用法實(shí)例分析

熱門(mén)標(biāo)簽:百應(yīng)電話機(jī)器人服務(wù) 岳陽(yáng)外呼型呼叫中心系統(tǒng)在哪里 騰訊外呼管理系統(tǒng) 揚(yáng)州地圖標(biāo)注app 青島語(yǔ)音外呼系統(tǒng)招商 昭通辦理400電話 山西回?fù)芡夂粝到y(tǒng) 山西探意電話機(jī)器人 河南電銷(xiāo)卡外呼系統(tǒng)哪家強(qiáng)

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

瀏覽器中為我們提供了一個(gè)JS對(duì)象XMLHttpRequet,它可以幫助我們發(fā)送HTTP請(qǐng)求,并接受服務(wù)端的響應(yīng)。

意味著我們的瀏覽器不提交,通過(guò)JS就可以請(qǐng)求服務(wù)器。 

ajax(Asynchronous Javascript And XML)其實(shí)就是通過(guò)XHR對(duì)象,執(zhí)行HTTP請(qǐng)求。  

1、創(chuàng)建XHR對(duì)象

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

2、XHR的對(duì)象屬性和方法

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

屬性:
//代表請(qǐng)求狀態(tài),不斷變化,為4時(shí),請(qǐng)求結(jié)束
readyState
//響應(yīng)的內(nèi)容
responseText
//響應(yīng)的狀態(tài)碼200,403,404
status
//狀態(tài)文字
statusText

事件:
//當(dāng)readyState變化時(shí)會(huì)觸發(fā)此事件
onreadystatechange = function() {};

3、通過(guò)XHR對(duì)象發(fā)送get請(qǐng)求

!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;
      //創(chuàng)建XHR對(duì)象
      var xhr = new XMLHttpRequest();
      //設(shè)置請(qǐng)求URL
      var url = "./ajax.php?con=" + con;
      //設(shè)置XHR對(duì)象readyState變化時(shí)響應(yīng)函數(shù)
      xhr.onreadystatechange = function () {
        //readyState是請(qǐng)求的狀態(tài),為4表示請(qǐng)求結(jié)束
        if (xhr.readyState == 4) {
          //responseText服務(wù)器響應(yīng)的內(nèi)容
          alert("服務(wù)器響應(yīng)數(shù)據(jù):" + this.responseText);
        }
      };
      //打開(kāi)鏈接
      xhr.open("get", url, true);
      //發(fā)送請(qǐng)求
      xhr.send(null);
    }
  /script>
/html>

ajax.php如下:

?php
$con = !empty($_GET['con']) ? trim($_GET['con']) : '沒(méi)有數(shù)據(jù)';
echo $con;

填入數(shù)據(jù),當(dāng)鼠標(biāo)焦點(diǎn)離開(kāi)input時(shí),觸發(fā)請(qǐng)求,彈出響應(yīng)內(nèi)容。  

4、通過(guò)XHR對(duì)象發(fā)送post請(qǐng)求

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

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

(3)、必須要設(shè)置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;
      //創(chuàng)建XHR對(duì)象
      var xhr = new XMLHttpRequest();
      //設(shè)置請(qǐng)求URL
      var url = "./ajax.php";
      //設(shè)置XHR對(duì)象readyState變化時(shí)響應(yīng)函數(shù)
      xhr.onreadystatechange = function () {
        //readyState是請(qǐng)求的狀態(tài),為4表示請(qǐng)求結(jié)束
        if (xhr.readyState == 4) {
          //responseText服務(wù)器響應(yīng)的內(nèi)容
          alert("服務(wù)器響應(yīng)數(shù)據(jù):" + this.responseText);
        }
      };
      //打開(kāi)鏈接
      xhr.open("post", url, true);
      //設(shè)置請(qǐng)求頭部
      xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
      //發(fā)送請(qǐng)求
      xhr.send("name=" + name + "pwd=" + pwd);
    }

  /script>
/html>

ajax.php如下:

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

單擊submit后發(fā)送post請(qǐng)求,彈出響應(yīng)信息。  

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

返回值只有兩種text,和xml。不過(guò)text內(nèi)容中可以是一段html或json結(jié)構(gòu)的字符串。  

(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 () {
      //創(chuàng)建XHR對(duì)象
      var xhr = new XMLHttpRequest();
      //設(shè)置請(qǐng)求URL
      var url = "./ajax.php";
      //設(shè)置XHR對(duì)象readyState變化時(shí)響應(yīng)函數(shù)
      xhr.onreadystatechange = function () {
        //readyState是請(qǐng)求的狀態(tài),為4表示請(qǐng)求結(jié)束
        if (xhr.readyState == 4) {
          //responseText服務(wù)器響應(yīng)的內(nèi)容
          //通過(guò)eval把傳來(lái)的json字符串轉(zhuǎn)成對(duì)象
          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;
        }
      };
      //打開(kāi)鏈接
      xhr.open("get", url, true);
      //發(fā)送請(qǐng)求
      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通過(guò)responseXML來(lái)讀取,responseXML不是字符串,是DOM對(duì)象。

!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 () {
      //創(chuàng)建XHR對(duì)象
      var xhr = new XMLHttpRequest();
      //設(shè)置請(qǐng)求URL
      var url = "./ajax.php";
      //設(shè)置XHR對(duì)象readyState變化時(shí)響應(yīng)函數(shù)
      xhr.onreadystatechange = function () {
        //readyState是請(qǐng)求的狀態(tài),為4表示請(qǐng)求結(jié)束
        if (xhr.readyState == 4) {
          //responseXML服務(wù)器響應(yīng)的內(nèi)容
          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;
        }
      };
      //打開(kāi)鏈接
      xhr.open("get", url, true);
      //發(fā)送請(qǐng)求
      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的同步與異步

通過(guò)設(shè)置open()的第三個(gè)參數(shù)true/false,來(lái)查看請(qǐng)求的效果。  

同步請(qǐng)求:

發(fā)送請(qǐng)求->等待結(jié)果->操作完成->繼續(xù)后面代碼。我們必須等待結(jié)果處理完畢后才能繼續(xù)后面的代碼,嚴(yán)格按照步驟一步一步執(zhí)行。  

異步請(qǐng)求:

發(fā)送請(qǐng)求->繼續(xù)后面代碼->響應(yīng)結(jié)果接收完畢->操作結(jié)果。異步請(qǐng)求在發(fā)送請(qǐng)求之后沒(méi)有等待結(jié)果的返回而是繼續(xù)執(zhí)行后面的代碼,也就是說(shuō)在結(jié)果返回之前用戶可以操作其他東西。

更多關(guān)于PHP相關(guān)內(nèi)容可查看本站專題:《PHP+ajax技巧與應(yīng)用小結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

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

標(biāo)簽:寶雞 南陽(yáng) 湛江 婁底 黃南 宜賓 鎮(zhèn)江 銅川

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《php下的原生ajax請(qǐng)求用法實(shí)例分析》,本文關(guān)鍵詞  php,下,的,原生,ajax,請(qǐng)求,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《php下的原生ajax請(qǐng)求用法實(shí)例分析》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于php下的原生ajax請(qǐng)求用法實(shí)例分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章