【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自定义表单组件,可以直接使用下面的代码:

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

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-08 16:54:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-08 16:54:04       100 阅读
  3. 在Django里面运行非项目文件

    2024-02-08 16:54:04       82 阅读
  4. Python语言-面向对象

    2024-02-08 16:54:04       91 阅读

热门阅读

  1. IP地址详解

    2024-02-08 16:54:04       62 阅读
  2. Kubernetes命令备忘单

    2024-02-08 16:54:04       42 阅读
  3. Kubernetes命令宝典:全面详解,不容错过!

    2024-02-08 16:54:04       49 阅读
  4. SQL 使用大全

    2024-02-08 16:54:04       58 阅读
  5. 【内网穿透】无公网ip远程访问本地项目

    2024-02-08 16:54:04       54 阅读
  6. 【小程序】基础API之系统API接口汇总

    2024-02-08 16:54:04       42 阅读
  7. 2.1 Verilog 基础语法

    2024-02-08 16:54:04       53 阅读