
本教程旨在解决从API获取数据并将其动态渲染到HTML页面时常见的逻辑错误。我们将深入探讨如何使用J*aScript的`fetch` API获取外部数据,并重点讲解如何利用数组的`map()`方法结合`join('')`高效且正确地将多个数据项转换为HTML结构,最终更新DOM,避免常见的迭代覆盖问题,确保所有预期内容都能被完整展示。
在现代Web开发中,从外部API获取数据并将其动态呈现在用户界面上是常见的需求。然而,在处理返回的数据列表时,开发者有时会遇到只显示最后一项内容的问题。本教程将详细分析这一问题,并提供一个健壮的解决方案。
当我们从API获取到一组数据(例如新闻列表)时,通常需要遍历这组数据,为每一项生成对应的HTML结构,然后将这些结构插入到页面的特定位置。一个常见的误区是在遍历过程中错误地更新一个字符串变量,导致最终只有最后一项数据被渲染。
考虑以下场景:我们有一个新闻API,返回一个包含多条新闻标题的数组。我们希望将这些标题显示在一个div容器内。
<div class="box" id="insert-news">
<div class="title">Marketplace </div>
<h2>Live News</h2>
<p><span class='highlight'>News Article</span></p>
<div class="aritcle_card">
<a class="aritcle_card_img" href="/ai/1084">
<img src="https://img.php.cn/upload/ai_manual/001/503/042/68b6c8f303e59213.png" alt="Kreado AI">
</a>
<div class="aritcle_card_info">
<a href="/ai/1084">Kreado AI</a>
<p>Kreado AI是一个多语言AI视频创作平台,只需输入文本或关键词,即可创作真实/虚拟人物的多语言口播视频。 为创作者提供AI赋能</p>
<div class="">
<img src="/static/images/card_xiazai.png" alt="Kreado AI">
<span>182</span>
</div>
</div>
<a href=&q
uot;/ai/1084" class="aritcle_card_btn">
<span>查看详情</span>
<img src="/static/images/cardxiayige-3.png" alt="Kreado AI">
</a>
</div>
<!-- 这里将动态插入新闻标题 -->
</div>在尝试将API返回的多条新闻标题渲染到HTML时,一个常见的错误模式是使用循环(或map方法但错误地使用其返回值)来构建HTML字符串,并在每次迭代中覆盖前一个结果。
以下是一个可能导致只显示最后一条新闻标题的错误代码示例:
function getData(){
fetch('https://api.coinstats.app/public/v1/news?skip=0&limit=10').then(response => {
return response.json();
}).then(data => {
console.log(data.news[2].title); // 调试用途
let newsTitle =''; // 初始化一个空字符串
data.news.map((values)=>{
// 每次迭代都会完全覆盖 newsTitle 的内容
newsTitle = `<div class="title">Marketplace </div>
<h2>Live News</h2>
<p><span class='highlight'>News Article</span></p>
<p>${values.title}</p>
</div>`;
});
// 最终只有最后一次迭代赋给 newsTitle 的值会被设置到 DOM 中
document.getElementById('insert-news').innerHTML = newsTitle;
});
}
getData();问题解析: 在这段代码中,data.news.map((values)=>{ ... })虽然使用了map方法,但其回调函数内部并没有返回任何值,并且newsTitle = ...这一行在每次循环中都将newsTitle变量重新赋值为一个全新的HTML字符串。这意味着,当map方法完成所有迭代后,newsTitle中存储的将是最后一条新闻的HTML结构。因此,当document.getElementById('insert-news').innerHTML = newsTitle;执行时,只有最后一条新闻会被渲染到页面上。
要正确地将API返回的所有新闻标题渲染到页面上,我们需要利用map方法生成一个HTML字符串数组,然后使用join('')方法将这些字符串连接成一个单一的、完整的HTML字符串。
以下是修正后的代码示例:
function getData() {
fetch("https://api.coinstats.app/public/v1/news?skip=0&limit=10")
.then((response) => {
// 确保响应成功,并解析JSON数据
if (!response.ok) {
throw new Error(`HTTP error! status: ${response.status}`);
}
return response.json();
})
.then((data) => {
// 检查数据结构,确保 news 数组存在
if (data && data.news && Array.isArray(data.news)) {
// 使用 map 遍历 news 数组,为每一项生成一个 HTML 字符串
// map 方法会返回一个由这些 HTML 字符串组成的新数组
const newsHtmlArray = data.news.map(
(values) =>
`<div class="news-item">
<div class="title">Marketplace </div>
<h2>Live News</h2>
<p><span class='highlight'>News Article</span></p>
<p>${values.title}</p>
</div>` // 注意这里将每个新闻项包裹在一个新的 div 中,以便区分
);
// 使用 join('') 将 HTML 字符串数组连接成一个单一的字符串
// 然后将其赋值给 innerHTML
document.getElementById("insert-news").innerHTML = newsHtmlArray.join("");
} else {
console.error("API返回的数据结构不符合预期或没有新闻数据。");
document.getElementById("insert-news").innerHTML = "<p>未能加载新闻。</p>";
}
})
.catch((error) => {
console.error("获取数据时发生错误:", error);
document.getElementById("insert-news").innerHTML = `<p>加载新闻失败: ${error.message}</p>`;
});
}
// 调用函数以获取并显示数据
getData();代码解析与最佳实践:
新闻1
", "新闻2
", ...]。新闻1
", "新闻2
", ...]转换为一个连续的字符串"新闻1
新闻2
..."。正确地从API获取数据并动态渲染列表内容是Web开发中的一项基本技能。通过理解Array.prototype.map()和Array.prototype.join('')的工作原理,我们可以避免常见的迭代赋值错误,高效且准确地生成并更新DOM。始终记住添加适当的错误处理和数据验证,以构建更健壮和用户友好的应用程序。
以上就是J*aScript教程:从API获取并正确渲染动态新闻列表的详细内容,更多请关注其它相关文章!
相关文章:
html网页设计源代码怎么运行_运行html网页设计源代码步骤【指南】
快手网页版在线登录 快手网页版官网入口快速访问
期待已久:小米17 Ultra、小米首款NAS本月登场
怎样更改Windows系统的默认安装路径_避免C盘爆满的终极设置【技巧】
12306选座如何查看座位示意图_12306座位示意图解读与使用
实现全屏滚动与导航点:专业教程
CSS条件样式无法按设备触发怎么排查_media条件语句正确设置解决触发问题
MAC怎么安装Homebrew包管理器_MAC为开发者和高级用户安装命令行工具
J*aScript设计模式实践_j*ascript代码优化
苹果手机如何防止被恶意App追踪
怎样在Excel中做仪表盘_Excel仪表盘设计与关键指标展示方法
PowerPoint如何制作滚动字幕结尾彩蛋_PowerPoint路径动画实现平滑滚动字幕效果
Go与Ruby之间实现AES加密互通:CFB模式下的密钥长度匹配策略
抖音网页版快捷访问 抖音网页版网页版入口操作教程
Excel中VLOOKUP的第四个参数是干什么用的_Excel VLOOKUP第四参数作用解析
J*aScript Promise链中如何正确终止后续.then执行并处理错误
Composer的 "check-platform-reqs" 命令有什么用_在部署前检查生产环境是否满足Composer依赖需求
快手官方唯一登录入口 谨防山寨钓鱼网站
AO3最新镜像入口 Archive of Our Own官方平台访问
Go语言HTML解析:利用Goquery精准获取指定元素内容
韩小圈电脑版在线入口_网页版免费登录地址
自动化J*a应用中GitHub CLI或REST API的认证与交互
如何修改开机登录密码_Windows账户安全设置超详细教程【必学】
Excel Power Pivot如何处理XML数据源 构建高级数据模型
Go调试环境为何无法启动_Go调试器启动失败原因与解决策略
微信语音通话掉线如何解决 微信语音通话稳定优化方法
特斯拉自动驾驶房车计划曝光 原型车将于2027年亮相
漫蛙2漫画入口 漫蛙正版网页漫画直达网址
抖音DOU+怎么投最有效 抖音付费推广的ROI提升技巧
蛙漫移动版在线看 蛙漫手机浏览器直达入口
为什么我的微信朋友圈看不到别人的更新_微信朋友圈更新显示异常解决方法
Lar*el DB::listen 事件中的查询执行时间单位解析
SteamMachine定价或为699美元 大家想入手吗?
C++如何连接MySQL数据库_C++使用Connector/C++操作MySQL数据库教程
如何让 composer 信任自签名的 HTTPS 证书源?
狙击外星人小游戏开始_狙击外星人小游戏立即开始
J*aScript中向JSON对象添加新属性的正确姿势
C++ map遍历方法大全_C++ map迭代器使用总结
Win11怎么开启省电模式_Win11电池节电模式自动开启
腾讯视频怎么举报不良内容_腾讯视频内容举报流程与违规信息处理方法
css滚动动画效果怎么实现_使用Animate.css滚动触发动画类
html怎么运行外部js文件中的函数_运html外js文件函数法【技巧】
sublime如何只显示或隐藏特定类型文件_sublime侧边栏文件过滤
J*aScript 字符串标签转换:使用正则表达式高效替换
单射、满射与双射的关系 一文理清所有逻辑
PHP面向对象编程中避免重复创建PDO数据库连接的最佳实践
vivo手机互传视频怎么操作_vivo手机互传视频详细传输方法
将JSON对象数组转置为键值对列表的实用指南
基于动态规划的房屋花卉种植最小成本算法详解
使用PHP从URL路径中提取倒数第二个片段