react 显示隐藏组件的方法_react 控制元素显示隐藏的3种方式

在 vue 中,元素的显示隐藏可以通过 指令 v-if 和 v-show 来控制。

v-if:适用于只渲染一遍的元素,或者此元素需要更新的,因为重新渲染 DOM 元素,会比较消耗性能。

v-show:适用于对元素进行频繁操作显示与隐藏的元素

然而,在 react中并没有如此方便的指令,react的显示与隐藏可以通过以下的3种方式来实现。

1、方法1

通过变量 showElem 的值 为 true or false 来控制元素是否渲染,为 true 则渲染,否则不渲染。

ea91488f206cd505c47c86452c2fcaad.png

2、方法2

通过行内样式 display 为 block 或 none 来控制显示和隐藏

e72253d6650f8f08e7e6a6ebc3d03f49.png

3、方法3

其实,方法3和方法2原理是相同的,都是通过样式display 为 block 或 none 来控制显示和隐藏,只不过,方法3是将样式写在类里面,然后通过是否返回这个类名来控制显示与隐藏。

.hide { display: none;} // 样式写在样式文件里即可

c9859cf7d0f7714e8111556c7dda5d30.png
  • 5
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用`useState`和`useEffect`钩子来实现监听滚动条的效果,然后根据滚动条的位置来控制按钮的显示隐藏。 代码示例如下: ```jsx import React, { useState, useEffect } from 'react'; const ScrollButton = () => { const [showButton, setShowButton] = useState(false); useEffect(() => { // 监听滚动条事件 window.addEventListener('scroll', handleScroll); // 组件卸载时移除滚动条事件监听 return () => { window.removeEventListener('scroll', handleScroll); } }, []); const handleScroll = () => { // 获取当前滚动条的位置 const scrollTop = document.documentElement.scrollTop || document.body.scrollTop; // 当滚动条超过 200px 时显示按钮 if (scrollTop > 200) { setShowButton(true); } else { setShowButton(false); } }; const handleClick = () => { // 点击按钮时回到页面顶部 window.scrollTo({ top: 0, behavior: 'smooth' }); }; return ( <button onClick={handleClick} style={{ display: showButton ? 'block' : 'none' }} > 返回顶部 </button> ); }; export default ScrollButton; ``` 在组件中,我们使用`useState`来保存按钮的显示状态,初始值为`false`。然后使用`useEffect`钩子来监听滚动条事件,并在组件卸载时移除该事件监听。 在`handleScroll`函数中,我们获取当前滚动条的位置,并根据位置来判断是否显示按钮。当滚动条超过 200px 时,将显示状态设置为`true`,否则设置为`false`。 最后,我们在组件中返回一个按钮元素,并在`style`属性中根据显示状态来设置按钮的`display`属性。当按钮显示时,点击按钮会回到页面顶部。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值