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

如何在反应中设置状态与数组中某个索引处的内容

如何解决如何在反应中设置状态与数组中某个索引处的内容

我有一系列评论,我想在某个索引处更新评论的状态,点击即可。有人可以解释为什么下面的代码不起作用吗?和 mabie 提供解决方案吗?评论通过道具传递。控制台日志显示我 2、2、3 和 2,2 3。我有 5 条评论。而且很奇怪,如果我评论 setReview 行,控制台会按预期显示

const InfoSection = ({ reviews}) => {
 let index = 1;
 let [review,setReview] = useState('some initial state');

 const paintNextReview = () => {
  //   index >= reviews.length ? (index = 0) : (index = index);
  setReview(reviews[index]);
   index++;
  console.log(index);
  
 };
 return(
 <div>
 
          <div >{review}</div>
          <button onClick={paintNextReview}> click</button>
 </div>
 )
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>

解决方法

是的,您也需要将索引作为状态变量:

const InfoSection = ({ reviews }) => {
  let [index,setIndex] = useState(1); // or should it be 0?
  let [review,setReview] = useState('some initial state');

  const paintNextReview = () => {
    setReview(reviews[index]);
    setIndex(index + 1);
  };
  return (
    <div>
      <div>{review}</div>
      <button onClick={paintNextReview}> click</button>
    </div>
  );
};

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