【React】如何使antd禁用状态的表单输入组件响应点击事件?

最近遇到一个需求,需要在<Input.textarea>组件中,设置属性disabled为true,使textarea响应点击事件,但直接绑定onClick并不会在禁用状态下被响应。

解决方法1

之后尝试了很多方法,比如设置csspointer-events:none,给textarea添加onMouseClick事件,在textarea父级套一层div,设置禁止向下传播均无效。但自己在原生textarea上启用pointer-events:none,是可以在disabled的情况下响应点击事件的。所以遇到这种情况,

第一种方法是,可以自己拿原生的textarea封装一个组件,修改pointer-events:none即可。

解决方法2

在textarea同级创建一个透明蒙层,把点击事件绑定在这个蒙层上。参考该链接

解决方法3

用antd的textarea组件,再自己套一层写成antd自定义表单组件,可以直接使用下面的代码:

ts 复制代码
import { useState } from 'react';
import { Input } from 'antd';

const { TextArea } = Input;

interface IProps {
    disabled: boolean;
    isSelected?: boolean;
    onClick: (a?: any) => void;
    onChange?: (a?: any) => void;
    children: string | undefined;
}

const CustomInput = (props: IProps) => {
    const { disabled, onClick = () => {}, isSelected = false, onChange } = props;
    const [inputValue, setInputValue] = useState('');
    const triggerChange = (value: any) => {
        onChange && onChange(value);
    };
    const handleInputValueChange = (e: any) => {
        setInputValue(e.target.value);
        triggerChange(e.target.value);
    };

    const handleClick = () => {
        if (disabled) {
            onClick();
        }
    };

    return (
        <div style={{ position: 'relative', backgroundColor: isSelected ? 'green' : '' }} onClick={handleClick}>
            <TextArea
                value={inputValue}
                onChange={handleInputValueChange}
                disabled={disabled}
                style={disabled ? { pointerEvents: 'none' } : {}}
            />
        </div>
    );
};

export default CustomInput;

如下示例,当disabled为true时,也可响应点击事件,令该文本框呈现选中状态。

相关推荐
ssshooter14 小时前
看完就懂 useSyncExternalStore
前端·javascript·react.js
青青家的小灰灰1 天前
迈向全栈新时代:SSR/SSG 原理、Next.js 架构与 React Server Components (RSC) 实战
前端·javascript·react.js
青青家的小灰灰1 天前
透视 React 内核:Diff 算法、合成事件与并发特性的深度解析
前端·javascript·react.js
小霖家的混江龙1 天前
从 0 到 1 实现一个 useState
前端·javascript·react.js
晓得迷路了1 天前
栗子前端技术周刊第 118 期 - Oxfmt Beta、Angular GitHub stars、React 基金会...
前端·javascript·react.js
AAA阿giao2 天前
从零构建一个现代登录页:深入解析 Tailwind CSS + Vite + Lucide React 的完整技术栈
前端·css·react.js
昨晚我输给了一辆AE862 天前
为什么现在不推荐使用 React.FC 了?
前端·react.js·typescript
不会敲代码12 天前
深入浅出 React 闭包陷阱:从现象到原理
前端·react.js
不会敲代码12 天前
React性能优化:深入理解useMemo和useCallback
前端·javascript·react.js
不会敲代码12 天前
从入门到进阶:手写React自定义Hooks,让你的组件更简洁
前端·react.js