vue3之组合式函数

抽取成一个组合式函数:

javascript 复制代码
// fetch.js
//接收响应式状态
import { ref, watchEffect, toValue  } from 'vue'
//一个封装的异步请求
import { fetch } from '../XX'
export function useFetch(url) {
	  const data = ref(null)
	  const error = ref(null)
	  const fetchData = () => {
	  	  // 重置data,error 数据
	      data.value = null
	      error.value = null
	      //toValue() 是一个在 3.3 版本中新增的 API。它的设计目的是将 ref 或 getter 规范化为值
		  fetch(toValue(url))
		    .then((res) => res.json())
		    .then((json) => (data.value = json))
		    .catch((err) => (error.value = err))
	  }
	 
	 watchEffect(() => {
	 	//只要fetchData函数中的url变就自动触发watchEffect
	   fetchData()
	 })
  return { data, error }
}

在组件里只需要这样使用:

javascript 复制代码
<script setup>
import { useFetch } from './fetch.js'

// 当 props.id 改变时重新 fetch
const { data, error } = useFetch(() => `/posts/${props.id}`)
</script>
相关推荐
问心无愧05131 天前
ctf show web入门160 161
前端·笔记
李小白661 天前
第四天-WEB服务器基本原理,IIS服务
运维·服务器·前端
humcomm1 天前
AI编程时代新前端职位
前端·ai编程
好家伙VCC1 天前
Web Components主题热切换方案揭秘
java·前端
甲维斯1 天前
Kimi版超级玛丽效果“惊人”,配额不足5厘米!
前端·人工智能
hboot1 天前
AI工程师第一课 - Python
前端·后端·python
凉菜凉凉1 天前
AI时代,被抛弃的前端
前端·ai
console.log('npc')1 天前
AI前端工程与生成式UI学习路线
前端·人工智能·ui
huangdong_1 天前
淘宝商品SKU图自动分类技术深度解析:从DOM解析到智能归档
开发语言·javascript·ecmascript
梦曦i1 天前
uni-router v1.1.1发布:守卫超时保护+路由监听
前端·uni-app