React 数据改变后页面没有重新渲染

页面通过render渲染,通过setState改变数据但是页面并未改变

import React, { Fragment } from 'react';
import { useState } from 'react';
import './index.less';

export default function Guide() {

  const introArr = [
    {
      id: 0,
      className: 'stepA',
      show: true
    },
    {
      id: 1,
      className: 'stepB',
      show: false
    }
  ]
  const [list, setList] = useState(introArr);

  const nextStep = (index: number) => {
    console.log("INDEX", index)
    // 遍历 introArr, (index + 1)的设为true, 其他设为false
    list.map((item: any) => {
       return item.show = false;
    })
    list[index + 1].show = true
    // 更改 list 的值
    // 数组对象是引用方式,值都是地址,地址没有改变
    setList(list)
  }

  return (
    <Fragment>
      {/* 黑色遮罩层 */}
      <div className="mask"></div>
      {/* 引导区 */}
      <div className="searchTip">
        {
          list.map((item: any, index: number) => (
            item.show && 
              <div className = {list[index].className}>
                <a className = "nextStep" onClick = {() => nextStep(index)}>下一步</a>
                <span className = "close"></span>
              </div>
            )
          )
        }
          
      </div>
    </Fragment>
  );
}

解决方法:浅拷贝方式获取对象并修改再赋值。

const newList = [...list]

原因: 对象数组是引用方式 ,对于react来说它的值都是地址(涉及到tree diff),因为没有被重新赋值(地址没有改变),所以 react 会认为仍然是之前的元素(element),则不更新视图。

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 如果想要数据改变重新渲染table,你可以使用JavaScript来实现。 一种方法是在数据改变后手动更新table的内容,例如: ``` var table = document.getElementById("myTable"); table.innerHTML = ""; // 清空table内容 for (var i = 0; i < newData.length; i++) { var row = table.insertRow(-1); for (var j = 0; j < newData[i].length; j++) { var cell = row.insertCell(-1); cell.innerHTML = newData[i][j]; } } ``` 另一种方法是使用一些框架或库,如React,Vue,Angular等,它们可以自动管理界面的渲染,并在数据改变重新渲染table。 例如,使用React,你可以这样写: ``` class Table extends React.Component { render() { return ( <table> <tbody> {this.props.data.map((row, i) => ( <tr key={i}> {row.map((cell, j) => ( <td key={j}>{cell}</td> ))} </tr> ))} </tbody> </table> ); } } ``` 然后,你可以在需要重新渲染table时,更新组件的props: ``` ReactDOM.render(<Table data={newData} />, document.getElementById("root")); ``` ### 回答2: 当数据发生改变时,需要重新渲染table,主要有以下几个步骤: 1. 获取最新的数据:首先,需要获取最新的数据,可以通过后台接口或者其他数据源来获取。例如,可以通过发送AJAX请求获取最新的数据。 2. 清空旧的table内容:在重新渲染table之前,需要先清空旧的table内容,以便后续重新填充新的数据。可以通过JavaScript操作,找到table元素,并将其内容清空。 3. 构建新的table结构:接下来,需要根据最新的数据构建新的table结构。可以通过JavaScript动态创建table、tr和td等元素,并将最新的数据绑定到对应的位置。 4. 填充新的数据:将最新的数据逐行逐列填充到新创建的table中。可以使用循环遍历数据,并使用JavaScript的appendChild方法将对应的数据添加到新创建的tr中。 5. 将新的table渲染页面:将新创建的table渲染页面中,使用户可以看到最新的数据。可以通过将新创建的table元素插入到页面中指定的位置,或者更新已有的table元素。 通过以上步骤,当数据发生改变时,可以重新渲染table,使得用户可以及时地看到最新的数据。在实际开发中,可以根据具体的需求和技术栈选择适合的方法和工具来实现数据重新渲染。 ### 回答3: 当数据发生改变时,重新渲染table是一个常见的需求。通常情况下,我们可以通过以下步骤来实现这个功能。 首先,我们需要将数据与table进行绑定。这可以通过将数据存储在一个数组或者对象中来实现。然后,我们可以使用循环语句(如for循环或者forEach函数)遍历数据,并在每次循环中使用innerHTML或者createElement等方法来动态创建table的行和列。 接下来,当数据发生改变时,我们需要更新table以显示最新的数据。这可以通过在数据变化的地方,即数据发生改变的函数或者事件处理函数中,调用重新渲染table的函数来实现。这个函数会先清空table的内容,然后重新根据最新的数据,调用相同的循环语句来创建或更新table的行和列。 在每次重新渲染table时,我们还可以根据数据的类型和需求,添加一些样式、条件判断或者其他操作。这可以通过在创建或更新table的行和列时,给元素添加class属性、设置样式等来实现。 最后,通过这种方式,当数据发生改变时,table会自动重新渲染,以显示最新的数据。这样,我们就可以方便地更新table,使其与数据保持同步。 需要注意的是,当数据量较大时,频繁地重新渲染table可能会降低性能。在这种情况下,可以考虑使用虚拟渲染等技术,以提高渲染效率。同时,我们也可以通过分页、滚动加载等方式,减少一次性渲染大量数据的压力。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值