react组件渲染两次
可能会有人问,问什么我的组件明明是就让渲染一次,但是实际上却渲染两次呢?其实我也遇到了这个问题,那么下面我提出一种解决这个问题的一种方法。
在react渲染组件中 , 初始化的index.tsx文件里,存在一个<React.StrictMode>标签,
这个是react的一个用来突出显示应用程序中潜在问题的工具(严格模式)
有一项检测意外的副作用,严格模式不能自动检测到你的副作用,但它可以帮助你发现它们,使它们更具确定性。通过故意重复调用以下函数来实现的该操作。
注意:这仅适用于开发模式。生产模式下生命周期不会被调用两次。
所以只需要把这个标签去掉就可以了
import React from 'react';
import ReactDOM from 'react-dom/client';
import './index.css';
import App from './App';
import reportWebVitals from './reportWebVitals';
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(
// <React.StrictMode>
<App />
// </React.StrictMode>
);
// If you want to start measuring performance in your app, pass a function
// to log results (for example: reportWebVitals(console.log))
// or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals
reportWebVitals();