本文旨在解决在 JavaScript 函数中插入加载指示器(Spinner)时遇到的问题,并提供两种基于 Promise 和 async/await 的解决方案,确保 Spinner 在数据处理完成前后正确显示和隐藏,提升用户体验。通过详细的代码示例和解释,帮助开发者理解异步操作的处理方式,避免常见的同步阻塞问题。
在 JavaScript 中,当执行耗时操作时,为了提升用户体验,通常会使用加载指示器(Spinner)来告知用户程序正在运行。 然而,直接在循环中使用 $.ajax 等异步方法,可能会导致 Spinner 的显示和隐藏与预期不符,例如 Spinner 立即消失,或者在数据处理完成前就消失。 这是因为 $.ajax 默认是异步执行的,循环会立即完成,而不会等待每个 AJAX 请求完成。
以下介绍两种解决该问题的方法:
async/await 是 JavaScript 中处理异步操作的一种简洁而强大的方式。 它可以使异步代码看起来像同步代码,从而更容易理解和维护。
立即学习“Java免费学习笔记(深入)”;
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) {}, }); } }
代码解释:
注意事项:
Promise.all() 接收一个 Promise 对象数组作为输入,并在所有 Promise 对象都 resolve 后 resolve。 这可以用于并行执行多个 AJAX 请求,并等待所有请求完成后再隐藏 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); 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) {}, }); }) ); }
代码解释:
优点:
注意事项:
以上两种方法都可以解决在 JavaScript 函数中插入加载指示器(Spinner)时遇到的问题。 async/await 方式更易于理解和调试,而 Promise.all() 方式可以并行执行 AJAX 请求,提高效率。 根据实际情况选择合适的方法。 记住,理解异步编程的概念是解决此类问题的关键。 确保在异步操作完成之后才隐藏 Spinner,才能为用户提供良好的体验。
以上就是JavaScript 函数中插入加载指示器(Spinner)的正确方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 //m.sbmmt.com/ All Rights Reserved | php.cn | 湘ICP备2023035733号