91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在php項目中使用原生ajax請求

發布時間:2021-03-08 14:10:30 來源:億速云 閱讀:135 作者:Leah 欄目:開發技術

如何在php項目中使用原生ajax請求?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

1、創建XHR對象

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

2、XHR的對象屬性和方法

方法:
open("get/post", url, true/false);
//有參數則k=v&k1=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=v&k1=v1&k2=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,來查看請求的效果。  

同步請求:

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

異步請求:

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

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

沈阳市| 芦溪县| 秀山| 会昌县| 康保县| 谷城县| 东乌珠穆沁旗| 景洪市| 仪征市| 马龙县| 镶黄旗| 新蔡县| 景谷| 淮安市| 莲花县| 怀集县| 内江市| 北辰区| 永年县| 新绛县| 石林| 兰州市| 遵化市| 专栏| 台东县| 腾冲县| 兴国县| 壶关县| 华宁县| 舞钢市| 义乌市| 乐都县| 镇赉县| 井陉县| 华安县| 延长县| 临清市| 大理市| 普兰店市| 蓬安县| 额敏县|