
本文旨在解决在 JavaScript 函数中插入 Spinner(加载指示器)时遇到的问题,并提供两种基于 Promise 和 async/await 的解决方案,确保 Spinner 在数据处理期间正确显示,并在处理完成后隐藏,从而提升用户体验。通过示例代码,详细讲解了如何利用 async/await 以及 Promise.all 来管理异步操作,保证 Spinner 的正确显示和隐藏。
在 JavaScript 中,经常需要在执行耗时操作时显示一个 Spinner,以告知用户程序正在运行。一个常见的场景是在数据插入数据库时。然而,由于 JavaScript 的异步特性,直接控制 Spinner 的显示和隐藏可能会遇到问题。以下介绍两种解决方案,利用 async/await 和 Promise.all 来确保 Spinner 的正确显示和隐藏。
async/await 使得异步代码看起来更像同步代码,从而更容易理解和维护。通过将 insertDataToDatabase 函数声明为 async,并在 $.ajax 调用前使用 await,可以确保 Spinner 在所有数据插入操作完成后才被隐藏。
document.getElementById("insert").addEventListener(
"click",
async function (event) {
event.preventDefault();
var spinner = document.getElementById("spinner");
spinner.style.display = "";
await insertDataToDatabase(results.data);
spinner.style.display = "none";
},
false
);
async function insertDataToDatabase(data) {
data_noheader = data.slice(1);
for (i = 0; i < data_noheader.length; i++) {
await $.ajax({
url: "index.php",
type: "POST",
dataType: "json",
data: {
action: 'import',
data: data_noheader[i],
},
success: function (response) {},
error: function (response) {},
});
}
}代码解释:
立即学习“Java免费学习笔记(深入)”;
注意事项:
如果数据插入的顺序不重要,可以使用 Promise.all 来并行处理数据,提高效率。
动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包
508
document.getElementById("insert").addEventListener(
"click",
async function (event) {
event.preventDefault();
var spinner = document.getElementById("spinner");
spinner.style.display = "";
await insertDataToDatabase(results.data);
spinner.style.display = "none";
},
false
);
async function insertDataToDatabase(data) {
data_noheader = data.slice(1);
await Promise.all(data_noheader.map((row) => {
return $.ajax({
url: "index.php",
type: "POST",
dataType: "json",
data: {
action: 'import',
data: row,
},
success: function (response) {},
error: function (response) {},
});
}));
}代码解释:
立即学习“Java免费学习笔记(深入)”;
优点:
注意事项:
以上两种方法都能够有效地在 JavaScript 函数中插入 Spinner,并确保 Spinner 在数据处理期间正确显示,并在处理完成后隐藏。选择哪种方法取决于你的具体需求。如果需要保证数据插入的顺序,使用 async/await 逐个处理;如果数据插入的顺序不重要,使用 Promise.all 并行处理可以提高效率。在实际开发中,根据具体情况选择合适的方案,能够更好地提升用户体验。
以上就是JavaScript 函数中插入 Spinner 的正确姿势的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号