微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

vue3 自定义 hooks 优雅处理异步调用 ajax

首先自定义一个专门处理异步的 hooks

import {reactive, toRefs} from "vue";
const useAsyncFn = (fn)=>{
    let data = reactive({value:undefined ,loading:false,err:undefined});
    const callBack = (...args)=>{
        data.loading = true;
        fn(...args).then((res)=>{
            data.value = res;
        },(err)=>{
            data.err = err
        }).finally(()=>{
            data.loading = false;
        })
    }

    return [toRefs(data),callBack];
}

export default useAsyncFn

  

用法为:

    let [data,callback] = useAsync(async(a)=>{
        let project = await fetch("/xxx?a="+a).then(res=>res.json());
        let iteration = await fetch("/xxx").then(res=>res.json());
        return {project,iteration}};
    })
    
      onMounted(()=>{
         callback(1)
      })
      

  

 

另外,如果想自动触发调用,可以进异步封装如下:

import useAsyncFn from "./useAsyncFn"
const useAsync = (fn)=>{
    const [ data,callback ] = useAsyncFn(fn);
    callback();
    return data;
}
export default useAsync;

  

用法为:

 let res = useAsync(async()=>{
        let project = await fetch("/xxx").then(res=>res.json());
        let iteration = await fetch("/xxx").then(res=>res.json());
        return {project,iteration}};
    })

  

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐