程序问答   发布时间:2022-06-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Ag 网格阻止访问 React 状态变量的当前值大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决Ag 网格阻止访问 React 状态变量的当前值

开发过程中遇到Ag 网格阻止访问 React 状态变量的当前值的问题如何解决?下面主要结合日常开发的经验,给出你关于Ag 网格阻止访问 React 状态变量的当前值的解决方法建议,希望对你解决Ag 网格阻止访问 React 状态变量的当前值有所启发或帮助;
@H_197_3@const [fromDate,setFromDate] = useState(moment().format('DD/MM/YY'));

function generatecolumnDefs(columnDefs) {
  return columnDefs.map(columnDef => {
      if (columnDef.fIEld === 'lob') {
        Object.assign(columnDef,{
          cellRendererFramework: loblinkRenderer
        });
      }   
    return columnDef;
  });
}

function loblinkRenderer(params) {
    return (
      <a onClick={() => handleClick(params)}>{params.value}</a>
    );
}

const test=()=>{
    return fromDate;
};

const handleClick = (params) => {
   let myDate1 = fromDate;
   let myDate2 = test();
}

return (
  <div>
     ...
     <button onClick={handleClick}>Test me </button>
  </div>
)

以上代码是构建 @H_197_3@agGrID 网格的 React 组件的一部分。某列的内容通过@H_197_3@cellRendererFramework转换为超链接。一旦点击这些超链接,@H_197_3@handleClick 就会被调用并填充 @H_197_3@myDate1 和 @H_197_3@myDate2。 我完全无法解释的是为什么 fromDate 没有其当前值。在上述情况下,尽管状态变量的值发生了多次变化,但它始终具有 @H_197_3@useState 提供的初始值,而不是当前值。同时,如果点击 @H_197_3@Test me 按钮,我会得到正确的 @H_197_3@fromDate...

解决方法

请查看这些答案:

  1. https://stackoverflow.com/a/55156813/13129018
  2. https://stackoverflow.com/a/60643670/13129018

根据您提供的代码,我建议将 @H_197_3@fromDate 绑定到 @H_197_3@useRef 容器:

@H_197_3@const fromDateRef = useRef(null);

fromDateRef.current = fromDate;

在您引用 @H_197_3@fromDate 的方法中,将其替换为 @H_197_3@fromDateRef.current:

@H_197_3@const test=()=>{
    return fromDateRef.current;
};

const handleClick = (params) => {
   let myDate1 = fromDateRef.current;
   let myDate2 = test();
}

大佬总结

以上是大佬教程为你收集整理的Ag 网格阻止访问 React 状态变量的当前值全部内容,希望文章能够帮你解决Ag 网格阻止访问 React 状态变量的当前值所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。