当前位置: 首页 > article >正文

使用XMLHttpRequest发送带查询参数的 GET 请求并动态展示数据

目录

目标

步骤说明

完整代码:

HTML 部分

代码解析:

总结:


在这个示例中,我们展示了如何使用 XMLHttpRequest 进行带有查询参数的 AJAX 请求。目标是通过 GET 请求向服务器传递参数,并获取与该参数相关的数据。以下是完整的代码和详细的讲解:

目标

  • 使用 XMLHttpRequest 对象与服务器进行异步通信,并携带查询参数。
  • 向服务器请求某个省的城市列表,展示广东省下属的所有城市。

步骤说明

  1. 创建 XMLHttpRequest 对象:首先我们创建了一个 XMLHttpRequest 对象,负责与服务器进行通信。
  2. 配置请求:使用 xhr.open() 方法配置请求,设置请求类型为 GET,并且添加查询参数 pname=广东省,请求 URL 是 http://hmajax.itheima.net/api/city?pname=广东省
  3. 监听 loadend 事件:当请求完成后,监听 loadend 事件,获取服务器返回的数据。
  4. 解析 JSON 数据:通过 xhr.response 获取响应内容,将其解析为 JSON 格式,并提取城市列表。
  5. 动态更新页面:使用 innerHTML 将城市列表显示到 HTML 页面中的 p 标签中。

完整代码:

HTML 部分
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>XMLHttpRequest_查询参数</title>
</head>

<body>
  <p class="city-p"></p>
  <script>
    /**
     * 目标:使用XHR携带查询参数,展示某个省下属的城市列表
    */
   const xhr = new XMLHttpRequest()
   // 这里是 GET 请求,并带有查询参数 pname=广东省
   xhr.open('GET','http://hmajax.itheima.net/api/city?pname=广东省')
   // 监听请求完成后的事件
   xhr.addEventListener('loadend', () => {
    // 将响应数据解析为 JSON 格式
    const data = JSON.parse(xhr.response)
    // 将城市列表显示到页面
    document.querySelector('.city-p').innerHTML = data.list.join('<br>')
   })
   // 发送请求
   xhr.send()
  </script>
</body>

</html>

代码解析:

  • XMLHttpRequest 对象const xhr = new XMLHttpRequest() 创建了一个新的 XMLHttpRequest 对象,负责与服务器通信。
  • open() 方法xhr.open('GET', 'http://hmajax.itheima.net/api/city?pname=广东省') 设定请求的 HTTP 方法为 GET,请求的 URL 为 'http://hmajax.itheima.net/api/city?pname=广东省'。这里的 pname=广东省 是我们传递给服务器的查询参数。
  • loadend 事件监听xhr.addEventListener('loadend', () => { ... }) 监听请求结束事件,并在请求结束后执行回调函数。该函数将返回的响应(JSON 格式数据)解析并处理。
  • JSON 解析const data = JSON.parse(xhr.response) 解析从服务器返回的 JSON 数据。
  • 动态更新页面document.querySelector('.city-p').innerHTML = data.list.join('<br>') 使用 innerHTML 将城市列表渲染到页面上,以 <br> 标签作为分隔符,使每个城市显示在新的一行。

总结:

该示例展示了如何使用 XMLHttpRequest 向服务器发送带有查询参数的请求,并展示如何在获取响应后动态地将数据渲染到页面中。在实际开发中,类似的技术可以用于与后端 API 交互,动态加载数据。

通过这个示例,你可以更好地理解如何使用 XMLHttpRequest 携带查询参数以及如何处理服务器返回的 JSON 数据。这种基本的 AJAX 技术对前端开发非常重要,尤其在需要与服务器进行异步通信时。


http://www.kler.cn/a/540430.html

相关文章:

  • 推荐一款 免费的SSL,自动续期
  • MacBook Pro M2安装deepseek
  • Gitlab中如何进行仓库迁移
  • at coder ABC 392
  • Qt监控设备离线检测/实时监测设备上下线/显示不同的状态图标/海康大华宇视华为监控系统
  • 网站快速收录策略:提升爬虫抓取效率
  • [LLM面试题] 指示微调(Prompt-tuning)与 Prefix-tuning区别
  • ndk 编译opencv(去除libandroid.so mediandk依赖)
  • 单片机复杂项目的软件分层设计
  • 构建jdk17包含maven的基础镜像
  • [安装FlashAttention] CUDA版本 和 Nvidia驱动版本
  • [Unity角色控制专题] 详细解释如何使用Character Controller配合脚本实现跳跃功能与落地抖动?
  • docker的卷映射如何手动指定位置
  • 信创领域的PostgreSQL管理员认证
  • 2.10学习总结
  • Qt中QTreeWidget的使用
  • 查出 product 表中所有 detail 字段包含 xxx 的完整记录
  • Linux常用命令——磁盘管理类
  • RTD2775QT/RTD2795QT瑞昱显示器芯片方案
  • Python 项目中创建虚拟环境(Virtual Environment)
  • JAVA 学习路线 学习大纲(java 进阶路线)
  • 利用子问题思路解决二叉树相关Oj题
  • 基于蜘蛛蜂优化算法的无人机集群三维路径规划Matlab实现
  • 力扣 单词拆分
  • 【网络安全.渗透测试】Cobalt strike(CS)工具使用说明
  • 测试某操作系统通过dd和UltraISO两种方式安装服务器(ARM)