antd hooks使用Editor 输入自动失焦的问题解决

antd官方文档里使用了类的react写法展示组件
直接复制代码进入自己的hooks项目中发现:
每输入一个字符,评论框就会自动失焦,需要再次点击才能继续输入。
出现这种情况是因为将Editor的定义放在了父组件内,挪到外部就可以了:

import { Comment, List, Input, Avatar, Form, Button } from 'antd'
import moment from 'moment'
const { TextArea } = Input

const Editor = ({ onChange, onSubmit, submitting, value }) => {
  return (
    <>
      <Form.Item>
        <TextArea rows={4} onChange={onChange} value={value} />
      </Form.Item>

      <Form.Item>
        <Button
          htmlType='submit'
          loading={submitting}
          onClick={onSubmit}
          type='primary'
        >
          评论
        </Button>
      </Form.Item>
    </>
  )
}

const CommentX = props => {
  const LIST = useContext(ListContext)
  const [value, setvalue] = useState('')
  const [submitting, setsubmit] = useState(false)
  const handleSubmit = () => {
    if (!value) {
      return
    }

    setsubmit(true)

    setTimeout(() => {
      setsubmit(false)
      setvalue('')
      addCom({
        comment: value,
        start: localStorage.getItem('score'),
        shopid: localStorage.getItem('shopID')
      })
        .then(res => {
          console.log(res)
        })
        .catch(err => {
          console.log(err)
        })
      LIST.setcomments([
        ...LIST.comments,
        {
          author: localStorage.getItem('username'),
          score: localStorage.getItem('score'),
          avatar:
            'https://zos.alipayobjects.com/rmsportal/ODTLcjxAfvqbxHnVXCYX.png',
          content: <p>{value}</p>,
          datetime: moment().fromNow()
        }
      ])
    }, 1000)
  }

  const handleChange = e => {
    setvalue(e.target.value) // !!!!
    console.log(value)
  }

  return (
    <>
      <Comment
        avatar={
          <Avatar
            src='https://zos.alipayobjects.com/rmsportal/ODTLcjxAfvqbxHnVXCYX.png'
            alt='Han Solo'
          />
        }
        content={
          <Editor
            onChange={handleChange}
            onSubmit={handleSubmit}
            submitting={submitting}
            value={value}
          />
        }
      />
    </>
  )
}

export default CommentX

因为每次输入都会对value进行同步,重新渲染CommentX组件,子组件Editor随之被重新渲染。
当二者定义代码处于同级位置时,问题就不存在了、。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用React Hooks和Antd的Form组件进行表单校,并且配合React-Draft-Wysig富文本框时,输入内容提示立即消失的问题可以通过以下方式解决: 首先,确已经安装了相关的依赖包: ` npm install antd react-draft-wysiwy draft-js ``` 然后,创建一个新的组件,命名为DemoForm: ``` import React, { useState } from ''; import { Form, Input, Button } fromantd'; import { EditorState, ContentState from 'draft-js'; import { } from 'react-draft-wysiwyg'; import 'react-draft-wysiwyg/dist/react-draft-wysiwyg.css'; const DemoForm = () => { const [editorState, setEditorState] = useState(EditorState.createEmpty()); const [form] = Form.useForm(); const handleFormSubmit = (values) => { console.log(values); }; const handleEditorChange = (state) => { setEditorState(state); }; return ( <Form form={form} onFinish={handleFormSubmit}> <Form.Item name="content" rules={[ { required: true, message: '请输入内容', }, ]} > <Editor editorState={editorState} onEditorStateChange={handleEditorChange} /> </Form.Item> <Form.Item> <Button type="primary" htmlType="submit"> 提交 </Button> </Form.Item> </Form> ); }; export default DemoForm; ``` 在上面的代码中,我们使用useState钩子来管理富文本框的编辑状态(editorState)和Form组件的表单状态(form)。onEditorStateChange函数用于更新编辑状态,handleFormSubmit函数用于处理表单提交。 在Form.Item组件中,我们使用了rules属性来进行表单校验。在这个例子中,我们要求content字段是必填的,如果没有输入内容,显示"请输入内容"的错误提示。 最后,通过使用Editor组件来展示富文本框,并且将editorState和handleEditorChange函数传递给它。 这样,在输入内容时,如果没有满足校验规则,显示错误提示,直到满足规则或者手动清空输入内容。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值