JavaScript函数中插入加载指示器(Spinner)的正确方法

javascript函数中插入加载指示器(spinner)的正确方法

本文旨在解决在JavaScript函数中正确插入和控制加载指示器(Spinner)的问题。通过利用async/await和Promise.all,确保在异步操作完成前后,加载指示器能够准确显示和隐藏,提升用户体验。文章提供了两种实现方案,并详细解释了其原理和优势,帮助开发者更好地理解和应用异步编程。

在Web开发中,加载指示器(通常是Spinner)用于向用户表明后台正在执行耗时操作。在JavaScript函数中,尤其是在处理异步操作时,正确地显示和隐藏加载指示器至关重要,可以提升用户体验。以下介绍两种常用的实现方案,并分析其优缺点。

使用 async/await 控制加载指示器

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) {},    });  }}

代码解释:

async function 声明异步函数,允许在函数内部使用 await 关键字。await 关键字用于等待一个Promise对象resolve。只有当Promise对象resolve后,才会继续执行后面的代码。在 click 事件处理函数中,首先显示加载指示器,然后使用 await 等待 insertDataToDatabase 函数完成。insertDataToDatabase 函数内部的 $.ajax 调用也使用了 await,确保每次Ajax请求完成后,才会进行下一次循环。

注意事项:

async/await 必须在 async 函数内部使用。await 只能等待Promise对象。如果等待的是其他类型的值,会被自动转换为Promise对象。如果 $.ajax 返回的不是 Promise 对象,需要将其包装成 Promise。

使用 Promise.all 并行执行异步操作

如果多个异步操作之间没有依赖关系,可以使用 Promise.all 并行执行,以提高效率。

代码示例:

立即学习“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);  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) {},    });  }));}

代码解释:

data_noheader.map((row) =youjiankuohaophpcn { … }) 将数据数组转换为一个包含Promise对象的数组。每个Promise对象代表一个Ajax请求。Promise.all(promiseArray) 接受一个Promise对象数组作为参数,并返回一个新的Promise对象。只有当数组中所有的Promise对象都resolve后,Promise.all 返回的Promise对象才会resolve。如果其中任何一个Promise对象reject,Promise.all 返回的Promise对象也会立即reject。await Promise.all(…) 等待所有Ajax请求完成。

优点:

可以并行执行多个异步操作,提高效率。

缺点:

如果其中一个异步操作失败,整个 Promise.all 都会失败,可能需要额外的错误处理。并行请求过多可能会导致服务器压力过大。

总结:

选择哪种方案取决于具体的应用场景。如果异步操作之间有依赖关系,或者需要对每个操作的结果进行处理,建议使用 async/await。如果异步操作之间没有依赖关系,且对性能要求较高,可以使用 Promise.all。无论选择哪种方案,都要确保在异步操作完成前后,加载指示器能够准确显示和隐藏,以提供良好的用户体验。

以上就是JavaScript函数中插入加载指示器(Spinner)的正确方法的详细内容,更多请关注php中文网其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/70969.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月13日 08:46:31
下一篇 2025年11月13日 09:08:54

相关推荐

  • Go 语言库与其他语言互操作性:核心挑战与限制

    本文探讨了将 go 语言编写的库直接从其他语言(如 c++++)调用的可行性。由于 go 语言独特的运行时模型、调用约定、垃圾回收机制和运行时初始化要求,使用标准 `gc` 编译器实现直接互操作性面临诸多挑战。文章详细分析了这些技术障碍,并简要提及 `gccgo` 编译器在此方面可能提供的灵活性。 …

    2025年12月16日
    000
  • Go database/sql 包:如何查询并打印多字段结果

    本文详细介绍了在go语言中使用`database/sql`包和`go-sql-driver/mysql`驱动时,如何从数据库查询中获取并打印多个字段。通过修改sql查询语句以选择所需列,并调整`rows.scan`方法以正确绑定多列数据到相应的go变量,文章演示了实现灵活数据检索和展示的关键步骤,并…

    2025年12月16日
    000
  • 使用 Go 处理包含非 JSON 内容的 JSON 流

    本文介绍了如何使用 Go 语言处理从标准输入读取的 JSON 数据流,该数据流中 JSON 结构体之间穿插着非 JSON 字符串(例如 “end”)。我们将探讨如何读取数据流,过滤掉非 JSON 内容,并将有效的 JSON 数据反序列化为 Go 结构体。 处理混合 JSON …

    2025年12月16日
    000
  • 如何在Golang中处理表单多字段验证

    答案:在Golang中处理表单多字段验证需结合结构体绑定与错误反馈,可使用%ignore_a_1%手动验证或第三方库如go-playground/validator提升效率。通过ParseForm解析数据并映射到结构体,手动检查字段有效性,适用于简单场景;对于复杂项目,推荐使用validator库,…

    2025年12月16日
    000
  • Go HTTP Server 中处理带有 Body 的 GET 请求

    本文介绍了在 Go HTTP 服务器中处理带有 body 的 GET 请求的方法。虽然 HTTP 规范不建议在 GET 请求中使用 body,但在某些特殊情况下可能需要处理此类请求。本文将探讨如何通过检查 Content-Length 头部或劫持连接来读取 GET 请求的 body,并提供修改标准库…

    2025年12月16日
    000
  • 深入理解Go语言HTTP服务器的并发处理机制

    go语言的`net/http`包构建的http服务器天生支持并发,每个传入请求都会在一个独立的goroutine中处理,从而避免阻塞。然而,用户在测试时可能会因浏览器自身的并发连接限制而产生服务器阻塞的错觉。本文将深入探讨go http服务器的并发原理,并通过示例代码和测试方法,帮助开发者正确理解并…

    2025年12月16日
    000
  • Go HTTP Handler 依赖注入:使用闭包优雅地传递类型

    本教程探讨了在go语言http服务中,如何将数据库连接等自定义类型或依赖项安全有效地传递给http处理函数。通过引入闭包(closure)的概念,我们能够避免使用全局变量,实现更清晰、可测试且易于维护的架构设计,确保每个请求处理都能访问到必要的资源。 在构建Go语言的Web应用程序时,HTTP处理函…

    2025年12月16日
    000
  • Go 包初始化机制详解

    go语言中,包的初始化是一个严格且有序的过程。无论一个包被程序中的多少个文件或多少个其他包导入,它都只会初始化一次。初始化流程包括按依赖顺序处理包级变量和常量,然后执行所有`init()`函数。这一机制确保了程序状态的确定性,并避免了重复初始化带来的潜在问题。 Go语言的包初始化机制是其程序执行模型…

    2025年12月16日
    000
  • Go Web服务:为何选择Nginx作为反向代理?

    在go语言web服务前部署nginx作为反向代理,能有效卸载日志记录、ssl/tls终止、http/2支持、gzip压缩、http头管理及静态文件服务等通用web服务器功能。这使得go应用专注于业务逻辑,提升了服务的性能、安全性与可维护性,避免了在go中重复实现这些复杂功能,实现了职责分离。 在构建…

    2025年12月16日
    000
  • 处理Go JSON流中的非JSON内容:一种实用教程

    本文针对Go语言处理JSON流时遇到的非JSON内容干扰问题,提供了一种有效的解决方案。通过读取字节切片、裁剪非JSON字符串,并使用JSON Unmarshaller进行解析,实现了在混合数据流中提取和处理JSON数据的能力。本教程将详细介绍该方法的实现步骤和代码示例,帮助开发者解决类似问题。 在…

    2025年12月16日
    000
  • Golang如何使用reflect获取变量类型

    答案:在Golang中,使用reflect.TypeOf可获取变量的类型信息,返回reflect.Type对象,通过Name()获取类型名,Kind()获取底层种类,支持指针、结构体等复杂类型的类型解析。 在Golang中,可以通过reflect包来获取变量的类型信息。核心是使用reflect.Ty…

    2025年12月16日
    000
  • 使用 gofmt 快速检查 Go 语言代码语法

    本文详细介绍了如何在go语言中仅检查源代码的语法错误,而无需进行完整的项目构建。核心方法是利用 `gofmt` 工具及其 `-e` 选项,它能有效报告文件中的所有语法问题。通过命令行示例和对 `gofmt` 选项的解析,教程展示了如何高效地进行语法验证,并探讨了如何利用其退出码在自动化流程中判断检查…

    2025年12月16日
    000
  • Go语言中实现有序Map迭代的策略与实践

    go语言内置的`map`类型不保证迭代顺序,如果需要按特定键序遍历,直接使用`map`会导致非确定性结果。本文将探讨go中实现有序map迭代的挑战,并介绍一种更符合go惯例的解决方案:选择使用b树或其他有序数据结构库,而非通过频繁地将`map`转换为排序切片。 理解Go语言Map的迭代顺序 Go语言…

    2025年12月16日
    000
  • Go语言中值转换为Go语法字面量表示的实践指南

    本文详细阐述了在go语言中,如何将各种数据类型(如字符串、整数、浮点数、复数乃至结构体)转换为其对应的go语法字面量表示。通过深入解析`fmt.sprintf`函数及其关键的`%#v`格式化动词,我们提供了清晰的代码示例和专业指导,帮助开发者在动态代码生成、调试输出或构建抽象语法树(ast)时,高效…

    2025年12月16日
    000
  • Go语言中如何获取变量的类型字符串

    在go语言中,获取变量的类型字符串是常见的需求,尤其对于熟悉其他语言(如javascript的typeof或python的type)的开发者而言。go没有内置的typeof操作符,但提供了两种主要方式:使用fmt.printf的%t格式化动词可以直接打印变量类型;若需将类型作为字符串值进行进一步处理…

    2025年12月16日
    000
  • Go语言中创建HTML表单模板的实践指南

    分别创建了用户名字段和密码字段。name属性对于表单提交至关重要,它定义了字段的键名。 创建了一个提交按钮。 解析与准备模板 定义了HTML字符串后,我们需要使用html/template包将其解析成可执行的模板对象。template.New()用于创建一个新的模板实例,Parse()方法则负责解析…

    2025年12月16日
    000
  • 如何在Golang中实现异步任务提升效率

    合理使用goroutine和channel可提升Go程序效率,通过go关键字启动异步任务,利用channel进行通信与同步,结合context实现超时控制与任务取消,配合WaitGroup协调批量任务完成,避免资源泄漏,从而高效利用多核资源。 在Golang中提升效率的关键方式之一就是合理使用异步任…

    2025年12月16日
    000
  • Go语言Unix域Socket Echo服务器实现与常见问题解析

    本文深入探讨了go语言中unix域socket echo服务器的实现细节,重点分析了`net.conn.read`操作中常见的缓冲区分配问题、`io.eof`的正确处理方式,以及`sync.waitgroup`在并发编程中作为参数传递时的注意事项。通过一个实际的示例代码,文章展示了如何构建一个健壮、…

    2025年12月16日
    000
  • 使用IntelliJ IDEA高效开发Go语言并实现自动化部署

    本文将指导您如何利用intellij idea及其go插件构建一个高效的go语言开发环境,并详细介绍如何配置ide以实现类似pycharm的自动化文件上传和部署功能,从而简化开发流程,提升部署效率。 在现代软件开发中,一个功能强大且集成度高的集成开发环境(IDE)对于提升开发效率至关重要。对于Go语…

    2025年12月16日
    000
  • Go语言中实现栈(LIFO)行为:通道的局限性与替代方案

    go语言的通道(channels)天生具备先进先出(fifo)的队列特性,无法直接配置为后进先出(lifo)的栈。当需要实现lifo行为,例如在深度优先搜索(dfs)中优化内存时,开发者应考虑使用go内置的切片(slice)来构建自定义栈,这是最直接且高效的解决方案。在某些特定场景下,`contai…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信