ホームページ >ウェブフロントエンド >jsチュートリアル >ajax の 3 つの解析モードを共有する

ajax の 3 つの解析モードを共有する

亚连
亚连オリジナル
2018-05-24 14:11:081305ブラウズ

この記事では主に、ajax の 3 つの解析モードの共有に関する関連情報を紹介します。必要な友人は参照してください

1. Ajax の JSON 形式

html コード:

<html>
<body>
 <input type="button" value="Ajax" id="btn">
 <script>
  var btn = document.getElementById("btn");
  btn.onclick = function(){
    var xhr = getXhr();
    xhr.open("post","10.php");
    xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
    /*
     * 在客户端如何构建JSON格式
     * * 构建符合JSON格式的字符串
     */
    var user = &#39;{"name":"zhangwuji","pwd":"123456"}&#39;;
    xhr.send("user="+user);
    xhr.onreadystatechange = function(){
      if(xhr.readyState==4&&xhr.status==200){
        var data = xhr.responseText;
        /*
         * 使用eval()函数进行转换
         * * 使用"()"将其包裹,eval()函数强制将其转换为JSON格式(javascript代码)
         * * 不使用"()"将其包裹,eval()函数将其识别为一个空的代码块
         */
        var json = eval("("+data+")");
        console.log(json);
      }
    }
  }
  function getXhr(){
    var xhr = null;
    if(window.XMLHttpRequest){
      xhr = new XMLHttpRequest();
    }else{
      xhr = new ActiveXObject("Microsoft.XMLHttp");
    }
    return xhr;
  }
 </script>
 </body>
</html>

PHP コード:

<?php
  // 接收客户端发送的请求数据
  $user = $_POST[&#39;user&#39;];
  // 就是一个JSON格式的string字符串
  //var_dump($user);
  $json_user = json_decode($user,true);
  //var_dump($json_user[&#39;name&#39;]);
  $json = &#39;{"a":1,"b":2,"c":3,"d":4,"e":5}&#39;;
  //var_dump(json_decode($json));
  // 响应数据符合JSON格式的字符串
  // 1. 手工方式构建
  //echo &#39;{"name":"zhouzhiruo","pwd":"123456"}&#39;;
  // 2. 使用json_encode()函数
  echo json_encode($json_user);
?>

二 Ajax の XML 形式

html ページ:

<html>
   <body>
 <input type="button" value="Ajax" id="btn">
 <script>
  var btn = document.getElementById("btn");
  btn.onclick = function(){
    // 实现Ajax的异步交互
    var xhr = getXhr();
    xhr.open("post","07.php");
    xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
    /*
     * 如何构建符合XML格式的请求数据
     * * 注意
     *  * 请求数据的格式 - key=value 不能改变的
     * * 将value值构建成符合XML格式的数据
     *  * 数据类型 - 字符串(string)
     *  * 格式符合XML的语法要求
     * * 编写注意
     *  * 定义变量 - 专门构建XML格式的数据
     *  * 在send()方法进行拼串
     */
    var user = "<user><name>zhangwuji</name><pwd>123456</pwd></user>";
    xhr.send("user="+user);
    xhr.onreadystatechange = function(){
      if(xhr.readyState==4&&xhr.status==200){
        // 接收服务器端的响应数据
        var xmlDoc = xhr.responseXML;
        var nameEle = xmlDoc.getElementsByTagName("name")[0];
        var txtEle = nameEle.childNodes[0];
        console.log(txtEle.nodeValue);
      }
    }
  }
  function getXhr(){
    var xhr = null;
    if(window.XMLHttpRequest){
      xhr = new XMLHttpRequest();
    }else{
      xhr = new ActiveXObject("Microsoft.XMLHttp");
    }
    return xhr;
  }
 </script>
 </body>
</html>

PHPページコード:

<?php
  // 接收客户端发送的请求数据
  $user = $_POST[&#39;user&#39;];//符合XML格式要求的string类型
  //var_dump($user);
  // 创建DOMDocument对象
  $doc = new DOMDocument();
  // 调用loadXML()方法
  $result = $doc->loadXML($user);
  //var_dump($doc);
  // 如何构建符合XML格式的数据
  /* 修改响应头的Content-Type值为"text/xml"
  header(&#39;Content-Type:text/xml&#39;);
  echo $user;// 符合XML格式的string类型
  */
  header(&#39;Content-Type:application/xml&#39;);
  echo $doc->saveXML();
?>

HTML形式Ajax で

上記は私が皆さんのためにまとめたものです。将来、皆さんのお役に立つことを願っています。

関連記事: iframeに基づいたajaxクロスドメインリクエストの実装Webページ内のajaxデータの取得

Ajax送受信リクエスト

Ajax非同期読み込みイメージの分析


以上がajax の 3 つの解析モードを共有するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。