【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时,也可响应点击事件,令该文本框呈现选中状态。

相关推荐
screct_demo1 小时前
詳細講一下在RN(ReactNative)中,6個比較常用的組件以及詳細的用法
javascript·react native·react.js
光头程序员10 小时前
grid 布局react组件可以循数据自定义渲染某个数据 ,或插入某些数据在某个索引下
javascript·react.js·ecmascript
limit for me10 小时前
react上增加错误边界 当存在错误时 不会显示白屏
前端·react.js·前端框架
浏览器爱好者10 小时前
如何构建一个简单的React应用?
前端·react.js·前端框架
VillanelleS13 小时前
React进阶之高阶组件HOC、react hooks、自定义hooks
前端·react.js·前端框架
傻小胖14 小时前
React 中hooks之useInsertionEffect用法总结
前端·javascript·react.js
flying robot1 天前
React的响应式
前端·javascript·react.js
GISer_Jing1 天前
React+AntDesign实现类似Chatgpt交互界面
前端·javascript·react.js·前端框架
智界工具库1 天前
【探索前端技术之 React Three.js—— 简单的人脸动捕与 3D 模型表情同步应用】
前端·javascript·react.js
我是前端小学生1 天前
我们应该在什么场景下使用 useMemo 和 useCallback ?
react.js