【发布时间】:2020-05-27 06:44:27
【问题描述】:
背景
我有一个 React 组件,其中包括另外两个组件。 I 组件包括一个图表(使用 react-charts 构建),另一个是一个简单的输入字段。我最初使不可见,但当有人单击那里的图标时它变得可见。
问题,当状态改变时子渲染
现在的问题是,每当我切换此输入字段时,它都会自动刷新我的图表。事实上,当我在输入字段中输入时,它也会刷新图表。我认为它会在我更新状态变量时重新呈现图形。我想停止这种行为。有关如何执行此操作的任何建议。
组件截图(https://i.imgur.com/zeCQ6FC.png)
组件代码
<div className="row">
<DealGraph ref={this.dealRef} />
<div className="col-md-4">
<div className="row">
<div style={style} className="col-md-12 bg-white border-radius-10 default-shadow">
<h3 className="sub-heading roboto" style={border}>
Create Deals
</h3>
<input
type="text"
name="deal"
className="form-control mgt-30"
value="Deal One"
readOnly
/>
<button
type="button"
onClick={this.showAddBlock}
style={button}
className="golden-button create-deal-button"
>
<i className="fa fa-plus"></i>
</button>
{addDealStatus ? (
<div className="col-md-12 add-deal-box pd-0-0">
<input
type="text"
className="form-control mgt-30 mgb-10"
name="add-deals"
placeholder="Add Deals"
/>
<button type="button" className="golden-button flex all-center">
Add
</button>
</div>
) : null}
</div>
</div>
</div>
</div>
切换功能
showAddBlock=() => {
this.setState({addDealStatus:!this.state.addDealStatus})
}
【问题讨论】:
-
使用简单变量或全局变量代替状态。
标签: reactjs typescript react-chartjs