微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何使用 React-hook-form 和 yup 验证 React-quill?

如何解决如何使用 React-hook-form 和 yup 验证 React-quill?

我用过

  • react-quill 用于表单元素之一。
  • react-hook-form 表单验证
  • 是的/是的,用于验证架构的解析器

正常输入和文本区域按预期工作,但对 react-quill 的验证不起作用。

这些是我的代码片段。

自定义 react-quill 包装元素

UnsatisfiedDependencyException

这是表单组件

import React,{ useRef,useState } from "react";
import PropTypes from "prop-types";
import Reactquill from "react-quill";
import "react-quill/dist/quill.sNow.css";
import "react-quill/dist/quill.bubble.css";
import "react-quill/dist/quill.core.css";

function Editor(props) {
  const [theme,setTheme] = useState("sNow");
  const { id,value,inputRef,placeholder,onChange } = props;

  return (
    <Reactquill
      id={id}
      ref={inputRef}
      theme={theme}
      onChange={onChange}
      value={value}
      modules={{
        toolbar: {
          ...Editor.modules.toolbar,handlers: {
            //   image: handleImageUpload,},...Editor.modules,}}
      formats={Editor.formats}
      bounds={".app"}
      placeholder={placeholder ?? ""}
    />
  );
}

/*
 * quill modules to attach to editor
 * See https://quilljs.com/docs/modules/ for complete options
 */
Editor.modules = {
  toolbar: [
    // [{ header: '1' },{ header: '2' },{ font: [] }],// [{ size: [] }],[{ size: ["small",false,"large","huge"] }],// custom dropdown
    [{ header: [1,2,3,4,5,6,false] }],["bold","italic","underline","strike","blockquote"],[
      { list: "ordered" },{ list: "bullet" },{ indent: "-1" },{ indent: "+1" },],["link","image","video"],["clean"],[{ color: [] },{ background: [] }],// dropdown with defaults from theme
    [{ font: [] }],[{ align: [] }],clipboard: {
    // toggle to add extra line breaks when pasting HTML:
    matchVisual: false,};
/*
 * quill editor formats
 * See https://quilljs.com/docs/formats/
 */
Editor.formats = [
  "header","font","size","bold","blockquote","list","bullet","indent","link","video",];

/*
 * PropType validation
 */
Editor.propTypes = {
  placeholder: PropTypes.string,};

export default Editor;

我检查了这些问题, https://github.com/zenoamaro/react-quill/issues/635

https://github.com/react-hook-form/react-hook-form/discussions/3372

但仍然无法正常工作。

当前行为

我在控制台(编辑器中的 onChange 函数)中确认了更改的降价,但在编辑器更改时看不到 useEffect 钩子的 formState 日志。 (无论是否向Controller添加规则道具)

任何帮助将不胜感激

谢谢

解决方法

export default function App() {
  const {
    register,handleSubmit,setValue,watch,formState: { errors }
  } = useForm();

  useEffect(() => {
    register("emailContent",{ required: true,minLength: 15 });
  },[register]);

  const onEditorStateChange = (editorState) => {
    setValue("emailContent",editorState);
  };

  const onSubmit = (data) => {
    console.log(data);
  };

  const editorContent = watch("emailContent");

  return (
    <div className="App">
      <ReactQuill
        theme="snow"
        value={editorContent}
        onChange={onEditorStateChange}
      />
      <p className="Error">{errors.emailContent && "Enter valid content"}</p>
      <input type="submit" onClick={handleSubmit(onSubmit)} />
    </div>
  );
}

我创建了一个代码沙箱,其中包含一个用于 react-hook-form 的工作示例。这是链接:

https://codesandbox.io/s/quill-with-react-hook-form-validation-cdjru

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?