键值对形式读取值

效果

学习啦!

异步请求数据方法:

async/await

<script setup>
import { nextTick, onMounted } from 'vue'let Info = {}const loadData = async () => {try {const response = await fetch('/json/info.json')const data = await response.json()data.forEach(item => {console.log(item, 'item')Info[item.userId] = item})console.log(Info, 'Info')} catch (err) {console.log(err)}
}onMounted(async () => {await loadData() // 等待数据加载完成nextTick(() => {let id = 'uj9'console.log(Info, 'Info') // 此时 Info 已经被填充let Aitem = Info[id]console.log(Aitem, 'Aitem')})
})
</script>

②使用 Promise

<script setup>
import { nextTick, onMounted } from 'vue'let Info = {}const loadData = () => {return new Promise((resolve, reject) => {fetch('/json/info.json').then(res => res.json()).then(data => {data.forEach(item => {console.log(item, 'item')Info[item.userId] = item})console.log(Info, 'Info')resolve()}).catch(err => {console.log(err)reject(err)})})
}onMounted(() => {loadData().then(() => {nextTick(() => {let id = 'uj9'console.log(Info, 'Info') // 此时 Info 已经被填充let Aitem = Info[id]console.log(Aitem, 'Aitem')})}).catch(err => {console.error('Error loading data:', err)})
})
</script>

③使用 Vue 的响应式系统

<script setup>
import { ref, nextTick, onMounted } from 'vue'let Info = ref({})const loadData = async () => {try {const response = await fetch('/json/info.json')const data = await response.json()data.forEach(item => {console.log(item, 'item')Info.value[item.userId] = item})console.log(Info.value, 'Info')} catch (err) {console.log(err)}
}onMounted(async () => {await loadData() // 等待数据加载完成nextTick(() => {let id = 'uj9'console.log(Info.value, 'Info') // 此时 Info 已经被填充let Aitem = Info.value[id]console.log(Aitem, 'Aitem')})
})
</script>

异步请求原理:

事件循环(Event Loop):

JavaScript 是单线程的,这意味着它一次只能执行一段代码。为了处理耗时的操作(如网络请求),JavaScript 使用事件循环机制。当一个异步操作(如 fetch 请求)被发起时,JavaScript 不会等待该操作完成,而是继续执行后续的代码。当异步操作完成时,其结果会被放入任务队列(Task Queue 或 Microtask Queue),等待事件循环的下一次迭代执行。

Promise :是一种处理异步操作的对象。它代表一个异步操作的最终完成(或失败)及其结果值。

fetch 返回一个 Promise,当请求完成时,Promise 会被解决(resolved)

//基本用法
fetch(url).then(response => response.json()) // 处理响应.then(data => console.log(data)) // 处理数据.catch(error => console.error(error)); // 处理错误

总结:

异步请求:通过 fetch 发起网络请求,返回一个 Promise

事件循环:JavaScript 使用事件循环机制处理异步操作,确保不会阻塞主线程,即不会影响线程。

Promise:用于处理异步操作的结果,包括成功和失败的情况。

nextTick:确保在 DOM 更新后执行某些操作

代码

json数据存放路径:/json/info.json
<template><div style="width: 100%;height: 100px; display: flex;align-items: center;" v-for="i in Aitem" :key="i.userId">艺名:<h1 style="color: brown;">{{ i.username }}</h1><br />姓名:<h1 style="color: blue;">{{ i.fullName }}</h1></div>
</template><script setup>
import { nextTick, ref, onMounted } from 'vue'let Info = {}const loadData = () => {return new Promise((resolve, reject) => {fetch('/json/info.json').then(res => res.json()).then(data => {data.forEach(item => {console.log(item, 'item')Info[item.userId] = item})console.log(Info, 'Info')resolve()}).catch(err => {console.log(err)reject(err)})})
}
const Aitem = ref([])
onMounted(() => {loadData().then(() => {nextTick(() => {let id = 'uj9'console.log(Info, 'Info') // 此时 Info 已经被填充Aitem.value = Info[id] ? [Info[id]] : []console.log(Aitem.value, 'Aitem')})}).catch(err => {console.error('Error loading data:', err)})
})
</script>
<style>
#app {width: 100%;height: 100vh;
}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/34990.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

Java面向对像编程OOP

&#x1f308;个人主页: Aileen_0v0 &#x1f525;热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 ​&#x1f4ab;个人格言:“没有罗马,那就自己创造罗马~” 文章目录 OOP总结&#xff1a; 类和对象的说明Java中有无static修饰的方法的使用区别&#xff1a;✅️有stat…

【MARL】MAT论文阅读笔记

文章目录 前言一、如何产生这个想法(TRPO -> ) PPO -> MAPPO -> HAPPO -> MAT 二、多智能体优势值分解定理三、transformer 在MAT的应用四、伪代码简述五、实验效果 前言 正好有节课让我们调研最新的自己的方向的新论文&#xff0c;找到一篇自己觉得比较可行&…

深度学习模型——双塔模型(Two-Tower Model)详解

双塔模型是一种高效、灵活的深度学习模型结构&#xff0c;广泛用于推荐系统和信息检索等场景中。其核心思想是分别为两个实体&#xff08;如用户和物品、查询和文档&#xff09;构建独立的特征表示网络&#xff08;两座塔&#xff09;&#xff0c;并在共享语义空间中通过相似性…

回溯里面的基本概念

1.深度优先遍历和深度优先搜索&#xff08;DFS) 深度优先遍历 主要思路是从图中一个未访问的顶点 V 开始&#xff0c;沿着一条路一直走到底&#xff0c;然后从这条路尽头的节点回退到上一个节点&#xff0c;再从另一条路开始走到底...&#xff0c;不断递归重复此过程&#xff…

LeetCode 热题100(十五)【动态规划】(3)

15.7最长递增子序列&#xff08;中等&#xff09; 题目描述&#xff1a;leetcode链接 300. 最长递增子序列 给你一个整数数组 nums &#xff0c;找到其中最长严格递增子序列的长度。 子序列 是由数组派生而来的序列&#xff0c;删除&#xff08;或不删除&#xff09;数组中的元…

springboot如何集成工作流审批流,流程设计器集成,业务表单和工作流绑定,详细步骤和实际案例参考(源码)

前言 activiti工作流引擎项目&#xff0c;企业erp、oa、hr、crm等企事业办公系统轻松落地&#xff0c;一套完整并且实际运用在多套项目中的案例&#xff0c;满足日常业务流程审批需求。 一、项目形式 springbootvueactiviti集成了activiti在线编辑器&#xff0c;流行的前后端…

02_Node.js模块化

02_Node.js模块化 知识点自测 以下代码运行的结果是多少&#xff1f; const arr [10, 20, 30] const result arr.map(val > val 1).reduce((sum, val) > sum val, 0) console.log(result) A&#xff1a;60 B&#xff1a;63 <details><summary>答案</…

vulnhub kioptirx1.2 超详细wp

探测 nmap --min-rate 10000 -p- 192.168.128.134 最小速率10000 nmap -sT -sV -sC -O 192.168.128.134 web打点 无弱口令 暴露cms寻找exp searchsploit LotusCMS -m 16982 [输入id号和参数m可以直接把东西复制到当前目录] 查看txt里面发现 都是xss没有rce github搜索到一个…

vulnhub靶场之【grotesque】三

前言 靶机&#xff1a;grotesque-3 192.168.1.44 攻击 &#xff1a;kali 192.168.1.16 都是虚拟机环境&#xff0c;桥接模式 主机发现 使用arp-scan -l或者netdiscover -r 192.168.1.1/24搜索 信息收集 使用nmap扫描 防止有遗漏&#xff0c;再扫描全端口 网站信息收集 …

大规模模型部署、推理的工具:Xinference

有没有 Xinference之前&#xff0c;如果想要部署应用一个开源模型&#xff0c;可能会面临以下一些情况和挑战&#xff1a; 自行开发推理框架&#xff1a; 需要投入大量的时间和精力来构建一个可靠且高效的推理框架&#xff0c;包括处理模型加载、资源管理、请求调度等复杂的任务…

C语言选择法排序

C语言编程&#xff0c;用选择法对数组中4个整数按由大到小排序 1、代码如下&#xff1a; #include<stdio.h> #include<math.h> #include<string.h>int main() {void sort(int array[],int n);printf("测试开始\n");int nums[] {2,3,4,1};sort(n…

SpringBoot的validation参数校验

文章目录 前言一、引入validation 依赖二、validation中的注解说明 &#xff08;1&#xff09;Validated&#xff08;2&#xff09;Valid&#xff08;3&#xff09;NotNull&#xff08;4&#xff09;NotBlank&#xff08;5&#xff09;NotEmpty&#xff08;6&#xff09;Patte…

Go的Gin比java的Springboot更加的开箱即用?

前言 隔壁组的云计算零零后女同事&#xff0c;后文简称 云女士 &#xff0c;非说 Go 的 Gin 框架比 Springboot 更加的开箱即用&#xff0c;我心想在 Java 里面 Springboot 已经打遍天下无敌手&#xff0c;这份底蕴岂是 Gin 能比。 但是云女士突出一个执拗&#xff0c;非我要…

docker学习笔记(四)--DockerFile

文章目录 一、什么是Dockerfile二、docker build命令三、dockerfile指令3.1 FROM3.2 ENV3.3 WORKDIR3.4 RUN3.5 CMD3.6 ENTRYPOINT3.7 EXPOSE3.8 ARG3.9 ADD3.10 COPY3.11 VOLUME 四、dockerfile示例 一、什么是Dockerfile Dockerfile 是用于构建 Docker 镜像的脚本文件&#…

撰写技术文档的关键步骤和核心要点

编写项目的技术文档是一个重要且细致的任务&#xff0c;它不仅有助于项目的当前开发团队理解系统的结构和工作原理&#xff0c;还为未来的维护和扩展提供了宝贵的参考资料。以下是撰写技术文档时应遵循的几个关键步骤和组成部分&#xff1a; 1. 概述 项目简介&#xff1a;简要…

Ant-Design-Vue 全屏下拉日期框无法显示,能显示后小屏又位置错乱

问题1&#xff1a;在全屏后 日期选择器的下拉框无法显示。 解决&#xff1a;在Ant-Design-Vue的文档中&#xff0c;很多含下拉框的组件都有一个属性 getPopupContainer可以用来指定弹出层的挂载节点。 在该组件上加上 getPopupContainer 属性,给挂载到最外层盒子上。 <temp…

【前端学习路线】(超详细版本)

先附上学习路线图&#xff1a;前端学习路线 第一阶段&#xff1a;前端入门&#xff08;htmlcss&#xff09; 前端最基本的知识&#xff0c;需要先将这些内容融汇贯通&#xff0c;学习后面内容才会不吃力。学习完可以做几个静态页练习一下。 推荐视频学习链接&#xff1a; 黑马程…

Vue生成类似于打卡页面

数据表格 <el-table :data"tableData" border height"calc(100vh - 240px)" :cell-style"cellFun"><el-table-column label"姓名" show-overflow-tooltip prop"name" align"center"/><el-table-co…

JVM学习《垃圾回收算法和垃圾回收器》

目录 1.垃圾回收算法 1.1 标记-清除算法 1.2 复制算法 1.3 标记-整理算法 1.4 分代收集算法 2.垃圾回收器 2.1 熟悉一下垃圾回收的一些名词 2.2 垃圾回收器有哪些&#xff1f; 2.3 Serial收集器 2.4 Parallel Scavenge收集器 2.5 ParNew收集器 2.6 CMS收集器 1.垃圾…

波特图方法

在电路设计中&#xff0c;波特图为最常用的稳定性余量判断方法&#xff0c;波特图的根源是如何来的&#xff0c;却鲜有人知。 本章节串联了奈奎斯特和波特图的渊源&#xff0c;给出了其对应关系和波特图相应的稳定性余量。 理论贯通&#xff0c;不在于精确绘…