React组件 -- Input封装

众所周知,antd的Input组件只有在被包裹在Form.Item中的时候才能进行校验;但是在很多情况下,需要对Input进行动态操作,这时需要对Input进行封装以获取更多操作权。

下面是对Input组件的一个封装,实现了原antd的Input组件valid状态展示的功能:

jsx 复制代码
const IInput = props => {
  let error = !props?.value;
  if (!props?.isChanged) {
    error = false;
  }
  return (
    <div>
      <Input
        styles={{
          input: {
            background: `${error ? '#fff' : 'auto'}`,
            borderColor: `${error ? '#ff4d4f' : 'auto'}`,
          },
        }}
        className={`${error ? 'input-status-error' : ''}`}
        {...props}
      ></Input>
      <div
        className={`ant-form-item-explain ${
          error ? 'ant-form-item-with-help' : 'ant-form-item-explain-connected'
        }`}
      >
        <div className="ant-form-item-explain-error">Please enter</div>
      </div>
    </div>
  );
};

封装好的组件在没有编辑之前不会进行value的合法性校验(由isChanged控制)

一旦编辑过,如果发现value是空则error的值就会变成true,此时会将提示信息和样式显示出来!

相关推荐
摘星编程5 分钟前
React Native鸿蒙版:AnimatedXY双轴动画完整代码
javascript·react native·react.js
艾斯特_16 分钟前
Echarts常用配置项及解释
前端·javascript·echarts
m0_5027249525 分钟前
飞书真机调试
开发语言·前端·javascript
我只会写Bug啊1 小时前
复制可用!纯前端基于 Geolocation API 实现经纬度获取与地图可视化
前端·高德地图·地图·百度地图·经纬度
刘一说1 小时前
Vue3 模块语法革命:移除过滤器(Filters)的深度解析与迁移指南
前端·vue.js·js
lkbhua莱克瓦242 小时前
JavaScript核心语法
开发语言·前端·javascript·笔记·html·ecmascript·javaweb
Trae1ounG2 小时前
这是什么dom
前端·javascript·vue.js
比老马还六2 小时前
Bipes项目二次开发/扩展积木功能(八)
前端·javascript
易营宝2 小时前
全球建站SaaS平台能提升SEO评分吗?是否值得切换?
大数据·前端·人工智能
C_心欲无痕2 小时前
Next.js 的服务端路由:对应api文件夹
开发语言·javascript·ecmascript