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

【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.dtcms.com/a/8114.html

相关文章:

  • 电力负荷预测 | 基于LSTM、TCN的电力负荷预测(Python)
  • Redisson看门狗机制
  • HomeAssistant系统添加HACS插件商店与远程控制家中智能家居
  • php 函数三
  • 【Java基础】Java如何正确判断字符串是否为空
  • 第一章 RocketMQ 概述
  • 关于RabbitMQ常见的十道面试题
  • 人工智能|深度学习——使用多层级注意力机制和keras实现问题分类
  • 安卓动态链接库文件体积优化探索实践
  • Elasticsearch的Index Lifecycle Management(ILM)
  • 前端JavaScript篇之强类型语言和弱类型语言的区别和对比
  • 《剑指offer》之左旋字符串
  • Vite 下一代的前端工具链,前端开发与构建工具
  • 零基础学编程从入门到精通,系统化的编程视频教程上线,中文编程开发语言工具构件之缩放控制面板构件用法
  • 动态数据源
  • Rust安装——Win10
  • 5年前端仔的2023年终总结
  • Linux C/C++ 原始套接字:打造链路层ping实现
  • CleanMyMac X 4.14.7帮您安全清理Mac系统垃圾
  • ElasticSearch搜索与分析引擎-Linux离线环境安装教程
  • Node.js的安装
  • Java后端须知的前端知识
  • ansible批量修改主机密码
  • Linux前后端程序部署
  • P9420 [蓝桥杯 2023 国 B] 子 2023 / 双子数--2024冲刺蓝桥杯省一
  • 如何以管理员身份删除node_modules文件
  • MATLAB实现二阶模糊逻辑控制系统仿真
  • 适用于 Windows 和 Mac 的 16 款最佳数据恢复软件
  • Leetcode 377 组合总和 Ⅳ
  • FlinkCDC全量及增量采集SqlServer数据