JavaScript异步编程——03-Ajax传输json和XML

Ajax 传输 JSON

JSON 的语法

JSON(JavaScript Object Notation):是 ECMAScript 的子集。作用是进行数据的交换。语法更为简洁,网络传输、机器解析都更为迅速。

语法规则:

  • 数据在键值对中

  • 数据由逗号分隔

  • 花括号保存对象

  • 方括号保存数组

数据类型:

  • 数字(整数或浮点数)

  • 字符串(在双引号中)

  • 逻辑值(true 或 false)

  • 数组(在方括号中)

  • 对象(在花括号中)

  • null

示例:

 // 对象
 {
   "name":"fox",
   "age":"18",
   "sex":"true",
   "car":null
 }
 ​
 // 数组
 [
   {
       "name":"小小胡",
       "age":"1"
   },
   {
       "name":"小二胡",
       "age":"2"
   }
 ]

JavaScript 中:json 字符串 <--> js 对象

基本上,所有的语言都有将 json 字符串转化为该语言对象的语法。

比如在 js 中:

  • JSON.parse():将 JSON 字符串转化为 js 对象。例如:

 // 将 JSON 字符串格式化为 js 对象
 var jsObj = JSON.parse(ajax.responseText);
  • JSON.stringify():将 JS 对象转化为 JSON 字符串。例如:

 var Obj = {
     name: 'fox',
     age: 18,
     skill: '撩妹',
 };
 ​
 console.log(Obj);
 ​
 // 将 js 对象格式化为 JSON 字符串
 var jsonStr = JSON.stringify(Obj);

PHP 中:json 字符串 <--> js 对象

  • json_decode()方法:将json字符串转化为变量。

  • json_encode()方法:将变量转化为json字符串。

代码举例:

 <?php
     header("Content-Type:text/html;charset=utf-8");
     // json字符串
     $jsonStr = '{"name":"itcast","age":54,"skill":"歌神"}';
     // 字符串转化为 php对象
       print_r(json_decode($jsonStr));
 ​
       echo "<br>";
       // php数组
       $arrayName = array('name' =>'littleFox' ,'age' => 13 );
       // php对象 转化为 json字符串
       print_r(json_encode($arrayName));
  ?>

输出结果:

     stdClass Object ( [name] => itcast [age] => 54 [skill] => 歌神 )
     {"name":"littleFox","age":13}
 ​

ajax 请求解析 json(举例)

(1)Person.json:

 {
     "name": "小强",
     "skill": "砍树",
     "friend": "老板"
 }

(2)myJson.php:

 <?php
 ​
     // 读取json文件 并返回即可
     echo  file_get_contents('info/Person.json');
 ​
  ?>

(3)getJson.html:

 
<!DOCTYPE html>
 <html lang="en">
     <head>
         <meta charset="UTF-8" />
         <title>Document</title>
     </head>
     <body>
         <h1>获取 json 数据</h1>
         <input type="button" value="获取json" id="btnJson" />
     </body>
 </html>
 <script type="text/javascript">
     // 获取的是一个 如果要获取多个
     // document.querySelectorAll(selector)
     document.querySelector('#btnJson').onclick = function () {
         var ajax = new XMLHttpRequest();
 ​
         ajax.open('get', 'myJson.php');
 ​
         ajax.send();
 ​
         ajax.onreadystatechange = function () {
             if (ajax.readyState == 4 && ajax.status == 200) {
                 // json 字符串 是字符串 所以我们可以 通过  responseText获取
                 console.log(ajax.responseText);
 ​
                 // 转化为 js对象
                 var jsObj = JSON.parse(ajax.responseText);
 ​
                 console.log(jsObj);
 ​
                 // 拼接ul s
                 var str = '';
 ​
                 str += '<ul>';
                 str += '<li>' + jsObj.name + '</li>';
                 str += '<li>' + jsObj.skill + '</li>';
                 str += '<li>' + jsObj.friend + '</li>';
                 str += '</ul>';
 ​
                 // 设置到界面上
 ​
                 document.body.innerHTML = str;
             }
         };
     };
 </script>

演示效果:

Ajax 传输 XML

XML 语法

XML(Extensible Markup Language):可扩展标记语言。详细语法可以查看:#。

1、XML 声明:

 <?xml version="1.0" encoding="UTF-8"?>

第一行的声明,指定了 XML 版本(1.0)以及使用的编码。

2、自定义标签:

XML 中没有默认的标签,所有的标签都是我们自己已定义的。例如:

 <fox></fox>
 <name></name>

XML 中没有单标签,都是双标签。

3、根节点:

XML 中必须要有一个根节点,所有的子节点都放置在根节点下。例如:

 <root1>
   <name></name>
 </root1>

XML 解析

因为 XML 就是标签,所以我们可以直接用解析 Dom 元素的方法解析 XML。

解析过程:

(1)html 部分:(包含 xml )

 <!DOCTYPE html>
 <html lang="en">
     <head>
         <meta charset="UTF-8" />
         <title>Document</title>
     </head>
     <body>
         <person id="personXML">
             <name>fox</name>
             <age>18</age>
             <skill>小花花</skill>
         </person>
     </body>
 </html>

(2)解析 xml:

 <script type="text/javascript">
     var xmlObj = document.getElementById('personXML');
     var name = xmlObj.getElementsByTagName('name')[0].innerHTML;
 ​
     console.log(name);
 </script>

ajax 请求解析 xml(举例)

(1)get_xml.php:(里面包含了 xml 文件)

 <?php
     // 设置 返回的为 xml
     header('content-type:text/xml; charset= utf-8');
 ​
     // 读取xml文件 并返回
     echo file_get_contents('info/star.xml');
 ​
  ?>

上方代码解释:

  • php 自带了 读取 xml 文件的方法。

  • 在 php 中,如果要使用 xml 传输数据,则需要使用 header()设置返回的内容为 xml。

(2)get_xml.html:(Ajax 请求,获取并解析 xml)

 <!DOCTYPE html>
 <html lang="en">
     <head>
         <meta charset="UTF-8" />
         <title>Document</title>
     </head>
     <body>
         <input type="button" value="获取XMl数据" id="getXML" />
     </body>
 </html>
 <script type="text/javascript">
     document.querySelector('#getXML').onclick = function () {
         var ajax = new XMLHttpRequest();
 ​
         ajax.open('get', 'get_XMl.php');
 ​
         ajax.send();
 ​
         ajax.onreadystatechange = function () {
             if (ajax.readyState == 4 && ajax.status == 200) {
                 // 如果 返回的是 xml文件
                 console.log(ajax.responseText);
 ​
                 // 异步 对象中 有另外一个属性 用来专门获取 xml
                 // xml对象 在浏览器段 就是一个 document对象
                 // 解析时 可以直接使用 querySelector 或者 getElementById等等 document对象 有的语法
                 console.log(ajax.responseXML);
                 console.log(ajax.responseXML.querySelector('kuzi').innerHTML);
                 // 下面这个 页面文档对象 如果要获取某个标签
                 console.log(window.document);
             }
         };
     };
 </script>

希望各位可以点个赞点个关注,这对up真的很重要,谢谢大家啦!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/600019.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

弹性云服务器是什么,为何如此受欢迎

云计算作为当下炙手可热的技术领域&#xff0c;已然成为现代企业不可或缺的核心能力。云服务器作为云计算的基石之一&#xff0c;在这个数字化时代发挥着至关重要的作用。而弹性云服务器&#xff0c;作为云服务器的一种演进形式&#xff0c;更是备受瞩目。 弹性云服务器&#…

使用 GPT-4-turbo+Streamlit+wiki+calculator构建Math Agents应用【Step by Step】

&#x1f496; Brief&#xff1a;大家好&#xff0c;我是Zeeland。Tags: 大模型创业、LangChain Top Contributor、算法工程师、Promptulate founder、Python开发者。&#x1f4dd; CSDN主页&#xff1a;Zeeland&#x1f525;&#x1f4e3; 个人说明书&#xff1a;Zeeland&…

自动化运维管理工具 Ansible-----【inventory 主机清单和playbook剧本】

目录 一、inventory 主机清单 1.1inventory 中的变量 1.1.1主机变量 1.1.2组变量 1.1.3组嵌套 二、Ansible 的脚本 ------ playbook&#xff08;剧本&#xff09; 2.1 playbook介绍 2.2playbook格式 2.3playbooks 的组成 2.4playbook编写 2.5运行playbook 2.5.1ans…

学习笔记:【QC】Android Q qmi扩展nvReadItem/nvWriteItem

一、qmi初始化 流程图 初始化流程: 1、主入口&#xff1a; vendor/qcom/proprietary/qcril-hal/qcrild/qcrild/rild.c int main(int argc, char **argv) { const RIL_RadioFunctions *(*rilInit)(const struct RIL_Env *, int, char **); rilInit RIL_Init; funcs rilInit…

【Linux】Linux线程

一、Linux线程的概念 1.什么是线程 1.一个进程的一个执行线路叫做线程&#xff0c;线程的一个进程内部的控制序列。 2.一个进程至少有一个执行线程 3.线程在进程内部&#xff0c;本质是在进程地址空间内运行 4.操作系统将进程虚拟地址空间的资源分配给每个执行流&#xff0…

基于51单片机的闭环反馈直流电机PWM控制电机转速测量( proteus仿真+程序+设计报告+原理图+讲解视频)

基于51单片机的闭环反馈直流电机PWM控制转速测量( proteus仿真程序设计报告原理图讲解视频&#xff09; 仿真图proteus7.8及以上 程序编译器&#xff1a;keil 4/keil 5 编程语言&#xff1a;C语言 设计编号&#xff1a;S0086 1. 主要功能&#xff1a; 基于51单片机的闭环…

js宏任务微任务输出解析

第一种情况 setTimeout(function () {console.log(setTimeout 1) //11 宏任务new Promise(function (resolve) {console.log(promise 1) //12 同步函数resolve()}).then(function () {console.log(promise then) //13 微任务})})async function async1() {console.log(async1 s…

语音识别--使用YAMNet识别环境音

⚠申明&#xff1a; 未经许可&#xff0c;禁止以任何形式转载&#xff0c;若要引用&#xff0c;请标注链接地址。 全文共计3077字&#xff0c;阅读大概需要3分钟 &#x1f308;更多学习内容&#xff0c; 欢迎&#x1f44f;关注&#x1f440;【文末】我的个人微信公众号&#xf…

2024.5.7

//头文件#ifndef MYWIDGET_H #define MYWIDGET_H#include <QWidget> #include <QPushButton> #include <QLineEdit> #include <QLabel> #include <QTextToSpeech> #include <QString> #include <QtDebug> #include <QIcon> #i…

js浏览器请求,post请求中的参数形式和form-data提交数据时数据格式问题(2024-05-06)

浏览器几种常见的post请求方式 Content-Type 属性规定在发送到服务器之前应该如何对表单数据进行编码。 默认表单数据会编码为 "application/x-www-form-urlencoded" post请求的参数一般放在Body里。 Content-Type&#xff08;内容类型&#xff09;&#xff0c;一般…

截图工具Snipaste:不仅仅是截图,更是效率的提升

在数字时代&#xff0c;截图工具已成为我们日常工作和生活中不可或缺的一部分。无论是用于工作汇报、学习笔记&#xff0c;还是日常沟通&#xff0c;一款好用的截图工具都能大大提升我们的效率。今天&#xff0c;我要向大家推荐一款功能强大且易于使用的截图软件——Snipaste。…

CRC校验原理及步骤

文章目录 CRC定义&#xff1a;CRC校验原理&#xff1a;CRC校验步骤&#xff1a; CRC定义&#xff1a; CRC即循环冗余校验码&#xff0c;是数据通信领域中最常用的一种查错校验码&#xff0c;其特征是信息字段和校验字段的长度可以任意选定。循环冗余检查&#xff08;CRC&#…

JUC-synchronized练习-交替打印ABC

今天来练习一下synchronized 简单来利用synchronized实现一个字符串的交替打印 主要的实现设置一个全局的变量state&#xff0c;线程执行通过不断累加state&#xff0c;根据state对三取余的结果来判断该线程是否继续执行还是进入等待。并通过synchronized锁住一个共享变量loc…

设计模式之模板模式TemplatePattern(五)

一、模板模式介绍 模板方法模式&#xff08;Template Method Pattern&#xff09;&#xff0c;又叫模板模式&#xff08;Template Pattern&#xff09;&#xff0c; 在一个抽象类公开定义了执行它的方法的模板。它的子类可以更需要重写方法实现&#xff0c;但可以成为典型类中…

学习R语言第五天

文章目录 语法学习创建数据的方式绘制图形的方式图形添加颜色如何操作数据的方式数据进行验算的判断加付值的方式修改变量名称的方式判断是否存在缺失值在计算的方式忽略缺失值通过函数的方式忽略缺失值日期处理的方式字符串转化成日期的方式格式化数据框中数据返回当前的日期的…

保研面试408复习 1——操作系统、计网、计组

文章目录 1、操作系统一、操作系统的特点和功能二、中断和系统调用的区别 2、计算机组成原理一、冯诺依曼的三个要点二、MIPS&#xff08;每秒百万条指令&#xff09;三、CPU执行时间和CPI 3、计算机网络一、各个层常用协议二、网络协议实验——数据链路层a.网络速率表示b.数据…

《十八》QThread多线程组件

本章将重点介绍如何运用QThread组件实现多线程功能。 多线程技术在程序开发中尤为常用&#xff0c;Qt框架中提供了QThread库来实现多线程功能。当你需要使用QThread时&#xff0c;需包含QThread模块&#xff0c;以下是QThread类的一些主要成员函数和槽函数。 成员函数/槽函数 …

Linux内核之获取文件系统超级块:sget用法实例(六十八)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a;多媒…

EMAIL-PHP功能齐全的发送邮件类可以发送HTML和附件

EMAIL-PHP功能齐全的发送邮件类可以发送HTML和附件 <?php class Email { //---设置全局变量 var $mailTo ""; // 收件人 var $mailCC ""; // 抄送 var $mailBCC ""; // 秘密抄送 var $mailFrom ""; // 发件人 var $mailSubje…

如何查看慢查询

4.2 如何查看慢查询 知道了以上内容之后&#xff0c;那么咱们如何去查看慢查询日志列表呢&#xff1a; slowlog len&#xff1a;查询慢查询日志长度slowlog get [n]&#xff1a;读取n条慢查询日志slowlog reset&#xff1a;清空慢查询列表 5、服务器端优化-命令及安全配置 安…
最新文章