自在猫先生 2024-09-02 09:20 采纳率: 62.9%
浏览 9
已结题

FluentUI9.2+React18.3实现div元素隐藏和显示功能

FluentUI9.2+React183.1实现当我点击用户图标的时候展开输入框,点击任意屏幕位置隐藏输入框。
遇到的问题是:当我点击用户图标展示输入框的时候想要给输入框中的下拉框选择数据,选择不了,会自动触发隐藏的事件

以下是部分的代码:
父组件:


 

function Parment()
{


  function toggleUserVisibility(){
    setiscomboxvisble(true);
  }
 return (
 
  
     <>
         <UserSelectComponets
          toggleUserVisibility={toggleUserVisibility}
          iscomboxvisble={iscomboxvisble}
}


        />
  </>
};

}export defalut Parment;
子组件
function UserSelectComponets(props){

  const 
  {
    iscomboxvisble,selectcomboxtext,isTextVisible,shiftUserComponent,onOptioncomboxdata,toggleUserVisibility,onHidecombxo,isUserIconClicked,handcombox

  } = props;
  const styles = useStyles();
  const comboId = useId("combo-default");
  const options = ["Cat", "Dog", "Ferret", "Fish", "Hamster", "Snake"];
  const inputRef = useRef(null);
  const userIconRef = useRef(null); // Add ref for the user icon
  const [comyVisble,setcomyVisble] = useState(false);


 
 
    useEffect(() => {
      debugger
      const handleClickOutside = (event) => {
        debugger
        if (inputRef.current && !inputRef.current.contains(event.target)&&
        userIconRef.current && !userIconRef.current.contains(event.target)) {
            onHidecombxo(); // Only hide if clicking outside both the input and the user icon

        }

       
    };

      document.addEventListener('mousedown', handleClickOutside);
      return () => {
          document.removeEventListener('mousedown', handleClickOutside);
      };
  }, [onHidecombxo]);
  



  const handleUserIconClick = (event) => {
    toggleUserVisibility();
    event.stopPropagation();  // Prevent the event from bubbling up
  };


  return (
    <>
      <div className={`nav-drop ${shiftUserComponent ? 'shift-left' : ''}`}
        ref={userIconRef}
        onClick={handleUserIconClick}
      >
        <text
         onMouseEnter={() => setcomyVisble(true)}
         onMouseLeave={() => setcomyVisble(false)}
        >
        {isTextVisible ? (selectcomboxtext || "120") : ""} 
        </text >
      </div>

      <div className={`nav-userintroduce ${comyVisble ? 'show' : ''}`}>
          <span>北京埃顿科技信息有限公司</span>
      </div>

      {iscomboxvisble&&(
        <div className={styles.root}>
          <div className="combox-input"
           ref={inputRef}
          >
          <Input>
          </Input>
          </div>
        
        <Combobox
              aria-labelledby={comboId}
              {...props}
              styles={comboBoxStyles} // 直接在组件内调整宽度
              className="user-combox"
            >
              {options.map((option) => (
                <Option key={option} disabled={option === "Ferret"}
                className={styles.combox}
                onClick={(event) => {
                  event.stopPropagation(); // Prevent event from bubbling up
                  onOptioncomboxdata(event, option);
                }}   
                >
                  {option}
                </Option>
              ))}
            </Combobox>
        </div>
       )}  
    </>
  );

}export default UserSelectComponets;

这个初始化的 useEffect方法 有影响
我现在点击用户的时候展开输入框 想要操作输入框一点击输入框就隐藏了。

img

img

img

展开全部

  • 写回答

1条回答 默认 最新

  • 自在猫先生 2024-09-09 06:12
    关注
    
    一共有三种情况:
    第一种 是点击这个120用户展开这个输入框
    第二种 是点击这个120用户展开这个输入框 再点击屏幕任意地方触发隐藏事件
    第三种 是点击这个120用户 展开这个输入框 再点击下拉框选择下拉数据给120这个用户重新赋值 (这理就跟第二种冲突了 可能调用到了隐藏事件 没法重新赋值 我把这个第二种情况注释掉就可以赋值 但是 点击屏幕任意地方隐藏输入框这个事件就不生效了)
    
    我点击屏幕任意地方算控件外部 那为什么我点击下拉框选择数据的时候难道也算控件外部???
    
      const handleClickOutside = useCallback((event) => {
        if (comboboxRef.current && !comboboxRef.current.contains(event.target)) {
          onHidecombxo();
        }
      }, [comboboxRef]);
      
      useEffect(() => {
        document.addEventListener('mouseup', handleClickOutside);
        return () => document.removeEventListener('mouseup', handleClickOutside);
      }, [handleClickOutside]);
    
    
    
     return (
        <>
          <div className={`nav-drop ${shiftUserComponent ? 'shift-left' : ''}`}
            onClick={handleUserIconClick}
          >
            <text
             onMouseEnter={() => setcomyVisble(true)}
             onMouseLeave={() => setcomyVisble(false)}
            >
            {isTextVisible ? (selectcomboxtext || "120") : ""} 
            </text >
          </div>
    
          <div className={`nav-userintroduce ${comyVisble ? 'show' : ''}`}>
              <span>北京埃顿科技信息有限公司</span>
          </div>
    
          {iscomboxvisble&&(
            <div className={styles.root}
            ref={comboboxRef} // 添加 ref
            >
              <div className="combox-input"
              >
              <Input>
              </Input>
              </div>
            
            <div>
            <Combobox
                  
                  aria-labelledby={comboId}
                  {...props}
                  styles={comboBoxStyles} // 直接在组件内调整宽度
                  className="user-combox"
                  onClick={(event) => {
                    event.stopPropagation(); // Prevent event from bubbling up
                    handcombox(event);
                  }}
                >
                  {options.map((option) => (
                    <Option key={option} disabled={option === "Ferret"}
                    className={styles.combox}
                    onClick={(event) => {
                      event.stopPropagation(); // Prevent event from bubbling up
                      onOptioncomboxdata(option,event);
                    }}
    
                    >
                      {option}
                    </Option>
                  ))}
                </Combobox>
            </div>
           
            </div>
           )}  
        </>
      );
    
    }export default UserSelectComponets;
    
    
    
    解决方案: 由于之前是写在一个组件中的 现在我把他分开来 我写两个组件 一个组件写展示输入框和赋值逻辑  一个组件专门写下拉框选择
    
    
    父组件
    
    function  Direction(){
    
      const [isVisible, setIsVisible] = useState(false); // 新增状态来控制显示/隐藏
      const [isSearchVisible, setSearchVisible] = useState(true); // 默认显示
      const [isUserVisible, setUserVisible] = useState(true); // 默认显示
      const [dropdownVisible, setDropdownVisible] = useState(false);
      const [isTextVisible, setIsTextVisible] = useState(true); // 控制文本的显示
      const [isAlertVisble,setIsAlertVisble] = useState(true);
      const [isPersonVisble,setISpersonVisble] = useState(true);
      const [shiftUserComponent, setShiftUserComponent] = useState(false);
      const [iscomboxvisble,setiscomboxvisble] = useState(false);
      const [isearchStatus,setisearchStatus] =  useState(false);
      const [isDropdownVisible, setIsDropdownVisible] = useState(false);
      const [isUserVisble,setisUserVisble] =useState(false);
      const [selectcomboxtext,setselectcomboxtext]= useState("");
      const [isAlertStatus,setisAlertStatus] = useState(false);
      const [isPersonIconClicked,setisPersonIconClicked] = useState(false);
      const [isInputVisble,setisInputVisble] = useState(false);
      const [isInputVisble2,setisInputVisble2] = useState(false);
    
      const handleHideInput = () => {
        setisInputVisble(false);
        setisInputVisble2(false);
       
      };
    
      const handleHidecombox=()=>{
       
          setiscomboxvisble(false);
          setSearchVisible(true);
          setIsAlertVisble(true);
      }
    
      function toggleUserVisibility(){
        setiscomboxvisble(prev => !prev); // 切换输入框的可见性
        setisInputVisble2(true);
        setSearchVisible(false);
        setIsAlertVisble(false);
        setisAlertStatus(true);
        setisearchStatus(true);
        setisUserVisble(false);
        
      }
    
      const handonOptionboxdata = (selectedOption,event) => {
        event.stopPropagation();
        setselectcomboxtext(selectedOption);
        setiscomboxvisble(false);
        setisUserVisble(true);
        setIsAlertVisble(true);
        setSearchVisible(true);
    
      };
    
     const handlecombox = (event)=>{
        event.stopPropagation();
        setSearchVisible(false);
      }
    
       <SelectedComboxData
             onOptioncomboxdata={handonOptionboxdata}
             handcombox={handlecombox}
             iscomboxvisble={iscomboxvisble}
            />
    
             <UserSelectComponets
              isUserVisible={isUserVisible}
              isTextVisible={isTextVisible}
              selectcomboxtext={selectcomboxtext}
              shiftUserComponent={shiftUserComponent}
              toggleUserVisibility={toggleUserVisibility}
              isInputVisble2={isInputVisble2}
              onHidecombxo={handleHidecombox}
            
    
    
            />
    }export default Direction;
    
    
    子组件
    
    function  UserSelectComponets(props){
    
     const 
      {
        isInputVisble2,selectcomboxtext,isTextVisible,shiftUserComponent,toggleUserVisibility,onHidecombxo
    
      } = props;
    
      const styles = useStyles();
      const inputRef = useRef(null); // Add ref for the user icon
    
      const [comyVisble,setcomyVisble] = useState(false);
    
    
    
      const handleClickOutside = useCallback((event) => {
        if (inputRef.current && !inputRef.current.contains(event.target)) {
          onHidecombxo();
        }
      }, [inputRef]);
      
      useEffect(() => {
        document.addEventListener('mouseup', handleClickOutside);
        return () => document.removeEventListener('mouseup', handleClickOutside);
      }, [handleClickOutside]);
    
    
    
      const handleUserIconClick = () => {
          toggleUserVisibility();  
      };
    
    
    
    
      return (
        <>
          <div className={`nav-drop ${shiftUserComponent ? 'shift-left' : ''}`}
            onClick={handleUserIconClick}
          >
            <text
             onMouseEnter={() => setcomyVisble(true)}
             onMouseLeave={() => setcomyVisble(false)}
            >
            {isTextVisible ? (selectcomboxtext || "120") : ""} 
            </text >
          </div>
    
          <div className={`nav-userintroduce ${comyVisble ? 'show' : ''}`}>
              <span>北京埃顿科技信息有限公司</span>
          </div>
    
          {isInputVisble2&&(
            <div className={styles.root}
          
            >
              <div className="combox-input"
                // ref={inputRef} // 添加 ref
              >
              <Input>
              </Input>
              </div>
            
            {/* <div>
            <Combobox
                  
                  aria-labelledby={comboId}
                  {...props}
                  styles={comboBoxStyles} // 直接在组件内调整宽度
                  className="user-combox"
                  onClick={(event) => {
                    event.stopPropagation(); // Prevent event from bubbling up
                    handcombox(event);
                  }}
                >
                  {userData.company.map((option) => (
                    <Option key={option} disabled={option === "Ferret"}
                    className={styles.combox}
                    onClick={(event) => {
                      event.stopPropagation(); // Prevent event from bubbling up
                      onOptioncomboxdata(option,event);
                    }}
    
                    >
                      {option}
                    </Option>
                  ))}
                </Combobox>
            </div> */}
           
            </div>
           )}  
        </>
      );
    
    }export default UserSelectComponets;
    
    
    
    子组件:
    
    function SelectedComboxData(props){
    
        const {
    
            handcombox,
            onOptioncomboxdata,
            iscomboxvisble
    
        } = props;
    
        const styles = useStyles();
        const comboId = useId("combo-default");
    
    return(
    
    <>
    
    {iscomboxvisble&&(
        <div className={styles.root}>
            <Combobox
                  
                  aria-labelledby={comboId}
                  {...props}
                  styles={comboBoxStyles} // 直接在组件内调整宽度
                  className="user-combox"
                  onClick={(event) => {
                    event.stopPropagation(); // Prevent event from bubbling up
                    handcombox(event);
                  }}
                >
                  {userData.company.map((option) => (
                    <Option key={option} disabled={option === "Ferret"}
                    className={styles.combox}
                    onClick={(event) => {
                        event.stopPropagation(); // Prevent event from bubbling up
                        onOptioncomboxdata(option,event);
                      }}
                    >
                      {option}
                    </Option>
                  ))}
                </Combobox>
            </div>
    
    
    )}
    
    </>
    
    )
    
    
    
    }export default SelectedComboxData;
    

    展开全部

    评论
    编辑
    预览

    报告相同问题?

    问题事件

    • 系统已结题 9月9日
    • 修改了问题 9月2日
    • 创建了问题 9月2日

    悬赏问题

    • ¥15 PADS Logic 原理图
    • ¥15 PADS Logic 图标
    • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
    • ¥20 气象站点数据求取中~
    • ¥15 如何获取APP内弹出的网址链接
    • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
    手机看
    程序员都在用的中文IT技术交流社区

    程序员都在用的中文IT技术交流社区

    专业的中文 IT 技术社区,与千万技术人共成长

    专业的中文 IT 技术社区,与千万技术人共成长

    关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

    关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

    客服 返回
    顶部