首页 > 其他分享 >探索Nuxt.js的useFetch:高效数据获取与处理指南

探索Nuxt.js的useFetch:高效数据获取与处理指南

时间:2024-07-18 15:01:16浏览次数:22  
标签:函数 URL js useFetch data cmdragon Nuxt


title: 探索Nuxt.js的useFetch:高效数据获取与处理指南
date: 2024/7/15
updated: 2024/7/15
author: cmdragon

excerpt:
摘要:“探索Nuxt.js的useFetch:高效数据获取与处理指南”详述了Nuxt.js中useFetch函数的使用,包括基本用法、动态参数获取、拦截器使用,及参数详解。文章通过示例展示了如何从API获取数据,处理动态参数,自定义请求和响应,以及useFetch和useAsyncData的参数选项,帮助开发者掌握异步数据加载技巧。

categories:

  • 前端开发

tags:

  • Nuxt.js
  • useFetch
  • API
  • 数据
  • 异步
  • Vue.js
  • SSR

freecompress-cmdragon_cn.png

扫描二维码关注或者微信搜一搜:编程智域 前端至全栈交流与成长

在构建现代Web应用时,数据获取是关键的一环。Nuxt.js,作为Vue.js的服务器渲染框架,提供了一系列强大的工具来简化数据获取流程。其中,useFetch
可组合函数是用于从API端点获取数据的高级封装,旨在与Nuxt的服务器端渲染(SSR)兼容。这个可组合函数提供了一个方便的封装,包装了useAsyncData
$fetch。它根据URL和fetch选项自动生成一个键,根据服务器路由提供请求URL的类型提示,并推断API响应类型。

useFetch的使用场景

useFetch主要用于在Nuxt应用中从API获取数据。它提供了一个方便的API,使得开发者能够以简洁的方式获取、处理和更新数据。这个函数可以用于任何需要从外部API获取数据的场景,如获取文章列表、用户信息、产品数据等。

示例:获取文章列表

假设我们有一个API端点https://api.example.com/articles,我们可以使用useFetch来获取文章列表:

<template>
  <div>
    <div v-if="pending">加载中...</div>
    <div v-else-if="error">{{ error }}</div>
    <div v-else>
      <ul>
        <li v-for="article in articles" :key="article.id">
          {{ article.title }}
        </li>
      </ul>
    </div>
  </div>
</template>

<script>
import { ref, onMounted } from 'vue';
import { useRoute } from 'vue-router';

export default {
  setup() {
    const route = useRoute();
    const { data, pending, error, refresh } = useFetch(`https://api.example.com/articles/${route.params.slug}`);

    onMounted(() => {
      // 刷新数据以确保获取最新的文章列表
      refresh();
    });

    return { data, pending, error, refresh };
  },
};
</script>
使用useFetch获取动态参数

假设API端点需要动态参数,如文章ID:

<script>
import { useRoute } from 'vue-router';

export default {
  setup() {
    const route = useRoute();
    const param1 = ref('value1');
    const { data, pending, error, refresh } = useFetch('https://api.example.com/articles', {
      query: { param1, param2: 'value2' }
    });

    return { data, pending, error, refresh };
  },
};
</script>
使用拦截器

拦截器允许开发者在请求和响应阶段进行自定义操作,如设置请求头、处理请求错误、存储令牌等:

<script>

export default {
  setup() {
    const { data, pending, error, refresh } = useFetch('/api/auth/login', {
      onRequest({ request, options }) {
        options.headers.authorization = 'Bearer ' + localStorage.getItem('token');
      },
      onResponse({ request, response, options }) {
        localStorage.setItem('token', response.data.token);
      }
    });

    return { data, pending, error, refresh };
  },
};
</script>

在Nuxt.js中,useFetch是一个强大的可组合函数,它允许你从不同的API端点异步获取数据。以下是对useFetch接收的参数的详细解释:

参数

1. URL

  • 类型string
  • 描述:这是你想要从API获取数据的URL。它可以是绝对路径或相对路径。相对路径将相对于当前页面的URL解析。

2. Options

  • 类型object

  • 描述:这是一个对象,包含了从unjs/ofetchAsyncDataOptions扩展而来的各种选项。以下是一些常见的选项:

    • methodstring- 请求方法,如'GET''POST''PUT''DELETE'等。
    • queryobject-
      一个对象,其键和值将被转换为查询字符串并附加到URL上。例如,{ param1: 'value1', param2: 'value2' }
      将生成?param1=value1&param2=value2
    • paramsobject- 与query类似,也是用于添加查询参数的对象。paramsquery的别名。
    • bodyany- 请求体,可以是对象、数组或其他任何可以被转换为字符串的值。如果传递的是对象,它将被自动转换为JSON字符串。
    • headersobject- 一个对象,包含了要发送的HTTP请求头。
    • baseURLstring- 请求的基本URL,所有请求都将相对于这个URL发送。
示例代码

以下是一个使用useFetch的示例,展示了如何使用这些参数:

async function fetchData() {
  const { data, pending, error, refresh } = await useFetch('https://api.example.com/data', {
    method: 'GET',
    query: { userId: 123 },
    headers: {
      'Content-Type': 'application/json',
      'Authorization': 'Bearer your-token'
    },
    body: {
      key1: 'value1',
      key2: 'value2'
    },
    baseURL: 'https://api.example.com'
  });

  // 处理数据
  if (!pending && !error) {
    console.log(data);
  }
}

在这个例子中,我们向https://api.example.com/data发送了一个 GET 请求,其中包含查询参数userId
,请求头,以及一个请求体。baseURL被设置为'https://api.example.com',这意味着所有的请求都将相对于这个URL发送。

注意事项
  • 如果同时提供了queryparamsuseFetch会将它们视为相同的选项。
  • body中的对象将被自动转换为JSON字符串,除非显式设置Content-Type请求头。
  • baseURL是可选的,如果未提供,则使用URL参数中的值。

useAsyncData 参数详解

useAsyncData是 Nuxt 3 提供的一个用于异步加载数据的可组合函数。以下是对useAsyncData接收的参数的详细解释:

1. key

  • 类型stringsymbol
  • 描述:一个唯一的键,用于确保数据获取可以在请求之间正确去重。如果未提供,useAsyncData将根据使用它的静态代码位置生成一个键。

2. server

  • 类型boolean
  • 描述:是否在服务器上获取数据。默认值为true。如果设置为false,则数据只会在客户端获取。

3. lazy

  • 类型boolean
  • 描述:是否在加载路由后解析异步函数,而不是阻止客户端导航。默认值为false。如果设置为true,则异步数据获取将不会阻塞路由导航。

4. immediate

  • 类型boolean
  • 描述:如果设置为false,将阻止立即发出请求。默认值为true,意味着异步函数会在组件初始化时立即执行。

5. default

  • 类型() => any(工厂函数)
  • 描述:一个工厂函数,用于设置数据的默认值,在异步函数解析之前使用。通常与lazy: trueimmediate: false选项一起使用。

6. transform

  • 类型(data) => any
  • 描述:在解析后可以用于更改处理函数结果的函数。这个函数接收原始数据作为参数,并返回转换后的数据。

7. pick

  • 类型string[]
  • 描述:仅从处理函数结果中选择指定的键。这允许你从响应中提取特定的数据片段。

8. watch

  • 类型boolean | Array
  • 描述:监听一组响应式源,并在它们发生变化时自动刷新获取的结果。默认情况下,会监听fetch选项和URL
    。通过设置watch: false,可以完全忽略响应式源。结合immediate: false,可以实现完全手动的数据获取。

9. deep

  • 类型boolean
  • 描述:以深层 ref 对象的形式返回数据。默认值为true。如果设置为false,则数据将在浅层 ref 对象中返回,这可以在不需要深层响应式数据时提高性能。

示例代码

返回值

1. data

2. pending

3. refresh/execute

4. error

5. status

默认行为

示例代码

余下文章内容请点击跳转至 个人博客页面 或者 扫码关注或者微信搜一搜:编程智域 前端至全栈交流与成长,阅读完整的文章:探索Nuxt.js的useFetch:高效数据获取与处理指南 | cmdragon’s Blog

往期文章归档:

标签:函数,URL,js,useFetch,data,cmdragon,Nuxt
From: https://blog.csdn.net/qq_42210428/article/details/140438288

相关文章

  • Nuxt.js 中使用 useHydration 实现数据水合与同步
    title:Nuxt.js中使用useHydration实现数据水合与同步date:2024/7/18updated:2024/7/18author:cmdragonexcerpt:摘要:介绍Nuxt.js中useHydration函数,用于控制客户端与服务器数据同步,实现数据水合。参数包括key、get和set函数,适用于多种场景,示例展示数据获取与显示流......
  • Nuxt.js 中使用 useHydration 实现数据水合与同步
    title:Nuxt.js中使用useHydration实现数据水合与同步date:2024/7/18updated:2024/7/18author:cmdragonexcerpt:摘要:介绍Nuxt.js中useHydration函数,用于控制客户端与服务器数据同步,实现数据水合。参数包括key、get和set函数,适用于多种场景,示例展示数据获取与......
  • 修复hangfire dashboard js css 404
    原本服务的地址模式是www.namespace-servicename.envname.complayname.io,按公司新的ingress标准更新了服务之后,变成www.clustername.complayname.io/namespace/servicename,可以看到原本服务名是在host部分里,现在host所有服务都是一样的,服务名放到后面的path里了,然而更新之后有......
  • Delphi原生JSON框架(二)TJsonArray
    前面写了如何快速读取一个JSON串,但只是针对简单的类型,如果JSON串中有数组该怎么办呢?一、例子代码先看下面的代码,读取一个学生的各科成绩。procedureTForm6.Button1Click(Sender:TObject);varjsonstr:string;jv:TJSONValue;js:TJSONString;ja:TJSONArray;jo......
  • Delphi原生JSON框架(一) TJsonValue
    Delphi自带了json支持,引用System.json,你就可以处理json,读写json格式的内容都是被支持的。发展了几个版本,无论性能及稳定性都已经成熟,我不喜欢引用更多的三方到项目中,所以,对于Delphi处理json来说,自带的是我的首选。目前,DelphiJson的实现,支持json所有的类型:TJSONObjectTJSONArra......
  • 快速上手FFUF:一款高效的网络模糊测试js文件爆破工具
    在网络安全领域,FFUF不仅是一款功能强大的工具,适用于目录发现、子域名发现、以及HTTP方法模糊测试,还是一款js爆破工具。本文将引导你快速掌握FFUF的使用方法,不需要复杂的背景知识,适合基础小白学习。什么是FFUF?FFUF,即FuzzFasterUFool,是一款用Golang编写的快速网络......
  • SSR理解(vite与nuxt比较)
    一、SSR的概念与理解(什么是SSR?)定义:SSR是指在服务器端完成页面的渲染工作,将最终生成的HTML内容发送给浏览器。简单来说,就是在服务器端将网页内容渲染成HTML,然后将这个渲染好的HTML发送到客户端,也就是我们的浏览器。原理:(渲染过程)传统的Web应用是在客户端(浏览器)通过Jav......
  • 可视化—gojs 超多超实用经验分享(四)
    目录41.监听连线拖拽结束后的事件42.监听画布的修改事件43.监听节点被del删除后回调事件(用于实现调用接口做一些真实的删除操作)44.监听节点鼠标移入移出事件,hover后显示特定元素45.监听树图实现鼠标点击节点本身展开或收起子节点的功能,而不是点击另外的按钮46.监听文本块编......
  • 第十三篇 Json模块
    JSON函数使用JSON函数需要导入json库:importjson。函数描述json.dumps将Python对象编码成JSON字符串json.loads将已编码的JSON字符串解码为Python对象json.dumpsjson.dumps用于将Python对象编码成JSON字符串。语法json.dumps(obj,skipkeys=False,en......
  • 基于java jsp ssm新闻文章发布管理系统微信小程序毕业设计实战项目分享
    前言......