首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将Quill输出设置为JSON/delta而不是html?

如何将Quill输出设置为JSON/delta而不是html?
EN

Stack Overflow用户
提问于 2021-04-26 09:38:29
回答 1查看 439关注 0票数 1

要将Quill的内容或输出设置为JSON/delta而不是HTML,我需要做些什么?

我不敢相信我问了这么简单的问题,但我在任何地方都找不到答案。

这里没有任何关于如何在QuillJS docreact-quill doc中设置格式的内容。

代码语言:javascript
复制
import React, { useState } from "react";
import ReactQuill, from 'react-quill';
import 'react-quill/dist/quill.snow.css';

export const Comment = () => {
  const [value, setValue] = useState('');

  function submit(e) {
      e.preventDefault();
      console.log(value) # This currently returns HTML instead of JSON
  }

  return (
    <>
        <ReactQuill theme="snow" value={value} onChange={setValue}/>
        <p>{value}</p>
        <button onClick={submit}>Submit</button>
    </>
  );
}
EN

回答 1

Stack Overflow用户

发布于 2021-05-26 09:33:25

看起来onChange prop是一个将HTML内容作为第一个参数的函数,它将是setState使用的值。您需要定义一个自定义函数,将value设置为editor.getContents(),这将返回一个表示当前文档的Delta。

代码语言:javascript
复制
import React, { useState } from "react";
import ReactQuill, from 'react-quill';
import 'react-quill/dist/quill.snow.css';

export const Comment = () => {
  const [value, setValue] = useState('');

  function submit(e) {
      e.preventDefault();
      console.log(value);
  }

  // onChange expects a function with these 4 arguments
  function handleChange(content, delta, source, editor) {
      setValue(editor.getContents());
  }

  return (
    <>
        <ReactQuill theme="snow" value={value} onChange={handleChange}/>
        <p>{value}</p>
        <button onClick={submit}>Submit</button>
    </>
  );
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67259843

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档