当前位置: 首页 > article >正文

【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的时候也可选中


http://www.kler.cn/a/231286.html

相关文章:

  • CSS核心
  • SSM开发(三) spring与mybatis整合(含完整运行demo源码)
  • AI学习指南HuggingFace篇-Hugging Face 的环境搭建
  • 留学生scratch计算机haskell函数ocaml编程ruby语言prolog作业VB
  • 98.1 AI量化开发:长文本AI金融智能体(Qwen-Long)对金融研报大批量处理与智能分析的实战应用
  • SpringBoot源码解析(八):Bean工厂接口体系
  • Spring GateWay
  • 鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之MenuItem组件
  • 阿里云ECS服务器Linux安装Mysql8
  • Vue中的 v-if 与 v-show 的区别
  • [项目管理] 如何使用git客户端管理gitee的私有仓库
  • 四:C语言-选择结构
  • 【大模型上下文长度扩展】MedGPT:解决遗忘 + 永久记忆 + 无限上下文
  • Rust 本地文档的使用:rustup doc
  • 【C#】.net core 6.0 设置根目录下某个文件夹可访问,访问创建的图片等资源
  • Appium使用初体验之参数配置,简单能够运行起来
  • rust给py写拓展如此简单
  • SQLite database实现加密
  • sklearn模型指标和特征贡献度查看
  • docker之程序镜像的制作
  • 有趣的CSS - 旋转的太极图
  • JVM-运行时数据区程序计数器
  • Flink实战六_直播礼物统计
  • 如何利用chatgpt提升工作效率
  • 数据结构——D/二叉树
  • 【芯片设计- RTL 数字逻辑设计入门 11 -- 移位运算与乘法】