Change the state when clicking outside a component in React(在 React 中单击组件外部时更改状态)
问题描述
我有一个下拉菜单,如下图所示:
I have a dropdown as is shown in the following image:
当我单击文件夹图标时,它会打开和关闭,因为 showingProjectSelector
属性处于设置为 false 的状态.
When I click the folder icon it opens and closes because showingProjectSelector
property in the state that is set to false.
constructor (props) {
super(props)
const { organization, owner, ownerAvatar } = props
this.state = {
owner,
ownerAvatar,
showingProjectSelector: false
}
}
当我单击该图标时,它会正确打开和关闭.
When I click the icon, it opens and closes properly.
<i
onClick={() => this.setState({ showingProjectSelector: !this.state.showingProjectSelector })}
className='fa fa-folder-open'>
</i>
但是我想要做的是在我点击下拉菜单时关闭它.我如何在不使用任何库的情况下做到这一点?
But what I'm trying to do is to close the dropdown when I click outside it. How can I do this without using any library?
这是整个组件:https://jsbin.com/cunakejufa/edit?js,输出
推荐答案
你可以尝试利用 onBlur
:
<i onClick={...} onBlur={() => this.setState({showingProjectSelector: false})}/>
这篇关于在 React 中单击组件外部时更改状态的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在 React 中单击组件外部时更改状态
基础教程推荐
- 如何使用TypeScrip将固定承诺数组中的项设置为可选 2022-01-01
- Vue 3 – <过渡>渲染不能动画的非元素根节点 2022-01-01
- 自定义 XMLHttpRequest.prototype.open 2022-01-01
- 直接将值设置为滑块 2022-01-01
- 我可以在浏览器中与Babel一起使用ES模块,而不捆绑我的代码吗? 2022-01-01
- 如何使用JIT在顺风css中使用布局变体? 2022-01-01
- 用于 Twitter 小部件宽度的 HTML/CSS 2022-01-01
- html表格如何通过更改悬停边框来突出显示列? 2022-01-01
- Chart.js 在线性图表上拖动点 2022-01-01
- Electron 将 Node.js 和 Chromium 上下文结合起来意味着 2022-01-01