0

0

使用JavaScript与SWAPI进行交互:构建正确的搜索查询URL

聖光之護

聖光之護

发布时间:2025-11-05 09:55:12

|

466人浏览过

|

来源于php中文网

原创

使用JavaScript与SWAPI进行交互:构建正确的搜索查询URL

本教程旨在解决使用javascript和axios库与swapi(星球大战api)进行交互时,因api请求url构造不当导致的404错误。文章将详细阐述如何正确构建包含用户输入作为搜索参数的api查询url,并提供完整的htmljavascript代码示例,帮助开发者有效地从swapi获取数据。

理解SWAPI与API查询基础

在使用JavaScript(特别是配合Axios库)与外部API(如SWAPI)进行数据交互时,一个常见的挑战是正确构造API请求的URL。当尝试根据用户输入动态查询数据时,如果URL结构不符合API的预期,通常会导致404 Not Found或ERR_BAD_REQUEST错误。

SWAPI(The Star Wars API)提供了一个丰富的星球大战数据集合,其查询机制遵循RESTful原则,并支持通过特定资源路径和查询参数进行搜索。

常见错误:不正确的API URL构造

许多开发者在初次尝试时,可能会将用户输入直接拼接在API的基础URL之后,期望API能自动识别并进行搜索。例如,如果用户输入“people”,则可能构造出类似https://swapi.dev/api/people的URL,这在查找特定资源时是正确的。但当用户输入的是一个搜索关键词(如“Luke”),并期望搜索所有人物中名为“Luke”的角色时,直接拼接成https://swapi.dev/api/Luke就会出错,因为SWAPI并没有名为“Luke”的顶级资源。

原始JavaScript代码中的错误示例:

立即学习Java免费学习笔记(深入)”;

// 错误的API请求构造方式
const userInput = form.elements.query.value; // 假设 userInput 是 "Luke"
const res = await axios.get(`https://swapi.dev/api/${userInput}`); // 导致请求 https://swapi.dev/api/Luke,SWAPI返回404

这种方式的问题在于,userInput被误认为是API的顶级资源路径,而非特定资源(如people)下的搜索参数。

DreamGen
DreamGen

一个AI驱动的角色扮演和故事写作的平台

下载

正确构建SWAPI搜索查询URL

SWAPI的搜索功能通常需要指定一个资源类型(例如/people/、/films/、/starships/等),然后通过URL查询参数?search=来传递搜索关键词。

以搜索人物为例,正确的URL结构应该是:https://swapi.dev/api/people/?search={userInput}。这里的people是资源类型,?search=是查询参数的起始标志,而{userInput}则是用户提供的搜索关键词。

修正后的JavaScript代码示例:

const form = document.querySelector('#searchForm');
form.addEventListener('submit', async function (e) {
    e.preventDefault(); // 阻止表单默认提交行为,防止页面刷新

    const userInput = form.elements.query.value; // 获取用户输入,例如 "Luke"
    console.log("用户输入:", userInput); // 调试用,确认用户输入已正确获取

    try {
        // 正确构建API请求URL:指定资源类型(例如 'people')并使用 'search' 查询参数
        // 这里的示例是搜索人物,如果需要搜索其他资源,请相应修改 'people'
        const res = await axios.get(`https://swapi.dev/api/people/?search=${userInput}`);

        const filmList = document.querySelector('.film-list'); // 获取用于显示结果的UL元素
        filmList.innerHTML = ''; // 清空之前的搜索结果

        if (res.data.results && res.data.results.length > 0) {
            res.data.results.forEach(person => {
                const listItem = document.createElement('LI');
                listItem.textContent = person.name; // 假设搜索人物,显示其名称
                filmList.append(listItem);
            });
        } else {
            const listItem = document.createElement('LI');
            listItem.textContent = `未找到与 "${userInput}" 相关的人物。`;
            filmList.append(listItem);
        }

    } catch (error) {
        console.error("API请求失败:", error);
        const filmList = document.querySelector('.film-list');
        filmList.innerHTML = `
  • 请求失败或未找到数据。请检查输入或网络连接。
  • `; } });

    完整的HTML结构

    为了配合上述JavaScript代码,前端HTML页面需要包含一个表单用于用户输入,以及一个用于显示搜索结果的列表。

    
    
    
        
        
        
        星球大战人物查找器
        
        
        
        
    
    
        

    星球大战人物查找器

    搜索结果:

      注意事项与调试技巧

      1. 查阅API文档: 任何时候与第三方API交互,第一步都应该是仔细阅读其官方文档。SWAPI的官方文档详细说明了其资源结构和查询方式。不同的API可能有不同的搜索参数(例如q、query、search等),或者需要API Key。
      2. 逐步测试: 在将用户输入集成到API请求之前,最好先硬编码一些搜索字符串,直接调用API并打印结果到控制台。这有助于确认API端点是否正确、返回的数据结构是否符合预期。
        // 独立测试示例
        async function testApi() {
            try {
                const testRes = await axios.get('https://swapi.dev/api/people/?search=Darth');
                console.log("测试结果:", testRes.data);
            } catch (error) {
                console.error("测试API失败:", error);
            }
        }
        testApi();
      3. 浏览器开发者工具: 利用浏览器的开发者工具(通常按F12打开),可以检查“网络”选项卡,查看实际发出的HTTP请求及其响应。这对于调试404、500等错误或检查返回数据非常有用。同时,“控制台”选项卡会显示JavaScript运行时错误和console.log输出。
      4. 错误处理: 在实际应用中,务必对API请求进行错误处理(使用try...catch块),以优雅地处理网络问题、API返回错误或其他异常情况,提升用户体验。
      5. 数据渲染: API返回的数据通常是JSON格式。在接收到数据后,需要根据其结构(例如res.data.results)来遍历并提取所需的信息,然后动态创建HTML元素来显示这些数据。

      总结

      正确构建API请求URL是与外部API成功交互的关键。对于SWAPI这类支持搜索功能的API,理解其资源路径和查询参数(如?search=)至关重要。通过指定正确的资源类型和利用查询参数传递用户输入,可以有效地避免404错误,并成功获取所需的数据。遵循API文档、进行逐步测试和利用开发者工具是调试和优化API集成过程中的最佳实践。

      相关专题

      更多
      js获取数组长度的方法
      js获取数组长度的方法

      在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

      544

      2023.06.20

      js刷新当前页面
      js刷新当前页面

      js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

      372

      2023.07.04

      js四舍五入
      js四舍五入

      js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

      727

      2023.07.04

      js删除节点的方法
      js删除节点的方法

      js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

      470

      2023.09.01

      JavaScript转义字符
      JavaScript转义字符

      JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

      392

      2023.09.04

      js生成随机数的方法
      js生成随机数的方法

      js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

      990

      2023.09.04

      如何启用JavaScript
      如何启用JavaScript

      JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

      654

      2023.09.12

      Js中Symbol类详解
      Js中Symbol类详解

      javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

      544

      2023.09.20

      php源码安装教程大全
      php源码安装教程大全

      本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

      74

      2025.12.31

      热门下载

      更多
      网站特效
      /
      网站源码
      /
      网站素材
      /
      前端模板

      精品课程

      更多
      相关推荐
      /
      热门推荐
      /
      最新课程
      Sass 教程
      Sass 教程

      共14课时 | 0.7万人学习

      Bootstrap 5教程
      Bootstrap 5教程

      共46课时 | 2.7万人学习

      CSS教程
      CSS教程

      共754课时 | 17.4万人学习

      关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
      php中文网:公益在线php培训,帮助PHP学习者快速成长!
      关注服务号 技术交流群
      PHP中文网订阅号
      每天精选资源文章推送

      Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号