Nextjs 集成富文本编辑器react-quill

目录

一、组件代码

二、参考文档


由于Next与react有些差别,直接调用组件会报无法找到文档的错误,于是我们只有考虑动态导入了解决问题。因为富文本编辑器一般作用与form页面对SEO意义不大,所以这里可以考虑暂时关闭SSR。

一、组件代码

/**
 * @author Dragon Wu
 * @since 2024/6/11 14:36
 */
import React, {useEffect, useState} from 'react';
import dynamic from 'next/dynamic';
import 'react-quill/dist/quill.snow.css';
import styles from "@/styles/publishTender.module.less";

const ReactQuill = dynamic(() => import('react-quill'), {ssr: false});

const TenderEditor: React.FC<{ defaultValue: string, onChange: Function }> = React.memo(({defaultValue, onChange}) => {

    const [editorValue, setEditorValue] = useState(defaultValue);

    const handleChange = (content) => {
        setEditorValue(content);
        onChange(content);
    };

    useEffect(() => {
        handleChange(defaultValue)
    }, [defaultValue]);

    return (<>
        <ReactQuill
            modules={{
                toolbar: [
                    ['bold', 'italic', 'underline', 'strike'],        // toggled buttons
                    ['blockquote', 'code-block'],
                    ['link', 'image', 'video', 'formula'],

                    [{ 'header': 1 }, { 'header': 2 }],               // custom button values
                    [{ 'list': 'ordered'}, { 'list': 'bullet' }, { 'list': 'check' }],
                    [{ 'script': 'sub'}, { 'script': 'super' }],      // superscript/subscript
                    [{ 'indent': '-1'}, { 'indent': '+1' }],          // outdent/indent
                    [{ 'direction': 'rtl' }],                         // text direction

                    [{ 'size': ['small', false, 'large', 'huge'] }],  // custom dropdown
                    [{ 'header': [1, 2, 3, 4, 5, 6, false] }],

                    [{ 'color': [] }, { 'background': [] }],          // dropdown with defaults from theme
                    // [{ 'font': [] }],
                    [{ 'align': [] }],

                    ['clean']                                         // remove formatting button
                ],
            }}
            value={editorValue}
            onChange={handleChange}
            theme="snow"
            placeholder="输入详情信息"
            className={styles.editor}
        />
    </>)
});

TenderEditor.displayName = "TenderEditor";

export default TenderEditor;

正常渲染,没有再报错:

二、参考文档

next.js - React Quill , unable to access import of Quill.import - Stack Overflow

react富文本编辑器 react-quill简单使用 - 简书

相关推荐

  1. react-quill文本编辑器空格回显无效

    2024-06-12 08:10:02       34 阅读
  2. react集成tinymce文本编辑器

    2024-06-12 08:10:02       21 阅读
  3. React文本编辑器wangEditor

    2024-06-12 08:10:02       39 阅读
  4. React文本编辑器开发(十)变换

    2024-06-12 08:10:02       15 阅读
  5. Taro(React)使用文本编辑器Editor

    2024-06-12 08:10:02       7 阅读
  6. React文本编辑器开发(十一)命令与编辑器

    2024-06-12 08:10:02       18 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-12 08:10:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-12 08:10:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-12 08:10:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-12 08:10:02       20 阅读

热门阅读

  1. 一个有趣的c++案例

    2024-06-12 08:10:02       7 阅读
  2. “手撕”二叉树的OJ习题

    2024-06-12 08:10:02       6 阅读
  3. jQuery Ajax 基本用法 附带Fetch API

    2024-06-12 08:10:02       7 阅读
  4. cd和pwd命令

    2024-06-12 08:10:02       3 阅读
  5. Date类

    2024-06-12 08:10:02       5 阅读
  6. LINUX

    LINUX

    2024-06-12 08:10:02      6 阅读
  7. Mongodb学习

    2024-06-12 08:10:02       8 阅读
  8. 【每日一题】01

    2024-06-12 08:10:02       6 阅读
  9. MYSQL execute command denied to user ‘‘@‘%‘ for routine

    2024-06-12 08:10:02       7 阅读