请教 useAxios (React Hooks) 的一个使用问题 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
请不要在回答技术问题时复制粘贴 AI 生成的内容
feng32
V2EX    程序员

请教 useAxios (React Hooks) 的一个使用问题

  • &nsp;
  •   feng32 2021-03-05 10:47:00 +08:00 2480 次点击
    这是一个创建于 1690 天前的主题,其中的信息可能已经有所发展或是发生改变。

    测试代码大概是这样的

    const OperatiOnButtons= ({record,}) => { const [{ data, loading, error}, refetch] = useAxios('http://www.baidu.com', {'manual': true}); return ( <Actions> <LinkButton OnClick={() => { Dialog.confirm({ title: "Confirm", content: 'Do you want to send request?', onOk: () => { refetch(); if (error) { console.log(error); } else { console.log(data); } } }); }} > Request </LinkButton> </Actions> ) } const TestTable = () => { const [{data, loading, error}, refetch] = useAxios('http://data.cdc.gov/data.json'); return ( <Table dataSource={data?.dataset} loading={loading} columns={[ { title: 'title', dataIndex: 'title', }, { title: 'identifier', dataIndex: 'identifier', }, { title: 'operations', cell: (value, index, record) => ( <OperationButtons record={record} /> ) } ]} /> ); }; 

    这里调用了一个公开数据集 ( http://data.cdc.gov/data.json) 来渲染一个表格 (TestTable),表格渲染是正常的。表格的第三列里有一个按钮,按下后会弹出一个确认对话框,点击 Ok 后,会发第二个请求。

    现在我想做的,是判断第二个请求成功与否,分别弹出一个成功对话框和失败对话框。

    因为这个文件是函数式组件,所以第二个请求也想使用 useAxios 来实现。现在如果打开浏览器的 CORS,第二个请求确实发出去了,但是现在判断逻辑有问题,始终输出 undefined

    请问这种情况下,第二个请求可以使用 axios-hooks 实现吗?如果可以,代码要如何调整呢?

    8 条回复    2021-03-05 18:18:22 +08:00
    duduaba
        1
    duduaba  
       2021-03-05 10:59:24 +08:00
    没用过这个,我感觉你是对 hooks 不理解。
    OperationButtons 里 refetch 是异步的,异步调用然后才根据数据变化执行 render,那这时候你 取 error 和 data 肯定获取不到 hooks 更新的信息对吧? 你看看可以加个 useEffect 监听 data 搞定。
    feng32
        2
    feng32  
    OP
       2021-03-05 11:16:27 +08:00
    @coderfuns 请教一下,TestTable 是一个函数 (函数式组件), okOk 也是个函数

    它们两在概念上有什么区别吗
    feng32
        3
    feng32  
    OP
       2021-03-05 11:16:52 +08:00
    okOk => onOk
    privatezcoding
        4
    privatezcoding  
       2021-03-05 11:26:57 +08:00
    http 请求是异步的,可以尝试使用 async await 转同步,再获取 data 和 error
    zhuweiyou
        5
    zhuweiyou  
       2021-03-05 11:32:41 +08:00   1
    useXX 的结果是一个 reactive 值, 你需要

    useEffect(() => {
    TODO:
    }, [监听的值])
    duduaba
        6
    duduaba  
       2021-03-05 14:02:45 +08:00
    @feng32 函数式组件只是 react 的一种组件写法返回的是 jsx 语法的 dom,onOk 是完全的 js 纯函数,肯定有区别的啊
    tangdw
        7
    tangdw  
       2021-03-05 17:57:38 +08:00
    refetch() 是异步函数吗?是的话 onOK 改一下,onOK 只会在点击后执行一次,函数组件会在 state 发生变化后执行

    ```js
    async () => {
    await refetch();
    if (error) {
    console.log(error);
    }
    else {
    console.log(data);
    }
    }
    ```
    islxyqwe
        8
    islxyqwe  
       2021-03-05 18:18:22 +08:00   1
    onOk: () => {refetch().then(resp=>console.log(resp.data), error => console.log(error));}
    或者
    useEffect(()=>{
    if (error) {
    console.log(error);
    }
    else {
    console.log(data);
    }
    },[data,error])
    /**...*/
    onOk: refetch
    楼上就属于不懂 hooks 了()
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     4211 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 25ms UTC 04:11 PVG 12:11 LAX 21:11 JFK 00:11
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86