ReactHooks, Next.js 与 Axios一起使用的问题

本文探讨在React Hooks和Next.js框架下,如何正确使用Axios获取接口数据。传统的在useEffect中获取数据的方法会导致无限循环,通过官方推荐的方式,可以在Next.js的getStaticProps或getServerSideProps中进行数据预取。
摘要由CSDN通过智能技术生成

前言

关于ReactHooks的介绍这里就不多说了,同时网上也有很多关于如何把React和Axios结合在一起使用的教程,近来也有很多如何使用ReactHooks和Axios一起使用的教程,这些教程获取接口数据的方式大多是用生命周期函数,包括在Hooks之前的生命周期函数以及Hooks中的新生命周期函数useEffect。而在Next.js这个SSR框架中情况是不一样的。

Hooks

这里主要参考了这篇文章,该文详细阐述了如何在React实现Hooks获取数据的基本步骤,简单说一下就是使用了useEffect这个Hooks自带的生命周期函数,当然这个函数和原来写在某个生命周期函数里面不同,这个是组件更新就会自动更新的,所以下面的写法会报错的:

import React, {
    useState, useEffect } from 'react';
import axios from 'axios';
function App() {
   
  const [data, setData] = useState({
    hits: [] });
  useEffect(async () => {
   
    const result = await axios(
      'https://hn.algolia.com/api/v1/search?query=redux',
    );
    setData(result.data);
  });
  return (
    <ul>
      {
   data.hits.map(item => (
        <li key={
   item
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值