如何使<hr>在反应羽毛笔中被识别?

时间:2020-04-18 00:56:30

标签: reactjs react-hooks quill

我正在尝试实现react羽毛笔钩子,并且无法将包含hr标记的字符串传递给value属性。

props.val === '<p>hello</p><h1>'

在线示例并没有真正将羽毛笔用作挂钩,但我想使用类似于现在的设置方式来尝试它。有没有办法像这样在钩子中实现除法器(hr)?到目前为止,这是我尝试过的:

import 'react-quill/dist/quill.snow.css'

import { Grid, LinearProgress } from '@material-ui/core'
import React, { useEffect, useRef, useState } from 'react'
import { Quill } from 'react-quill'

var Embed = Quill.import('blots/block/embed')
class Hr extends Embed {
    static create(value) {
        return super.create(value)
    }
}

Quill.register({
    'formats/hr': Hr,
})
export function TextEditor(props) {
    const [editor, setEditor] = useState(<LinearProgress />)
    let quillRef = null // Quill instance
    const [reactQuillRef, setReactQuillRef] = useState(useRef(null)) // ReactQuill component
Hr.blotName = 'hr'
Hr.className = 'hr'
Hr.tagName = 'hr'
var customHrHandler = function() {
    // get the position of the cursor
    var range = 0
    console.log(range)
    if (range) {
        // insert the <hr> where the cursor is
        quillRef.insertEmbed(range, '<hr>', 'null')
    }
}

const textEditorModuleSettings = {
    toolbar: [
        [{ header: [] }],
        [
            'bold',
            'italic',
            'underline',
            'strike',
            { color: [] },
            { background: [] },
        ],
        [
            { list: 'ordered' },
            { list: 'bullet' },
            { indent: '-1' },
            { indent: '+1' },
        ],
        ['link', 'clean'],
        [
            {
                container: '#toolbar',

                handlers: {
                    hr: customHrHandler,
                },
            },
        ],
    ],
}

useEffect(() => {
    import('react-quill')
        .then(res => {
            const Quill = res.default
            console.dir(res)
            setEditor(
                <Quill
                    className={props.className}
                    maxLength={props.maxLength || 1500}
                    modules={props.modules || textEditorModuleSettings}
                    onChange={props.change}
                    ref={el => {
                        setReactQuillRef(el)
                    }}
                    theme={props.theme || 'snow'}
                    value={props.val}
                />
            )
        })
        .catch(console.log)
}, [])

useEffect(() => {
    if (!reactQuillRef.current) {
        reactQuillRef.current = true
    } else {
        attachQuillRefs()
    }
    if (reactQuillRef.editor) {
        quillRef = reactQuillRef.getEditor()
        //quillRef.insertEmbed(0, 'html', '<hr>')
    }
}, [reactQuillRef, quillRef])

return editor

}

0 个答案:

没有答案