Word Press富文本控件的保存

新建富文本编辑器,并编写save方法如下:

edit方法:

js 复制代码
export default function Edit({ attributes, setAttributes }) {
	return (
		<>
		<div { ...useBlockProps() }>
			<RichText
				tagName='p'
				onChange={ (value) => setAttributes({ noteContent: value })}
				value={attributes.noteContent}
				placeholder='输入你的内容...'
				>

			</RichText>
			<div>自定义的按钮</div>
		</div>
		</>
	);
}

save方法:

js 复制代码
import { useBlockProps } from '@wordpress/block-editor';

export default function save({ attributes }) {

    const { noteContent } = attributes;

    return (
        <div { ...useBlockProps.save() }>
            { noteContent }
        </div>
    );
}

看上去很好理解,将RichText标签解析成div,将内容保存在div内部。

报错

此时保存刷新:

报错内容:

text 复制代码
区块包含未预料的或无效的内容。

此时打开控制台能够看到报错的log:

text 复制代码
Content generated by `save` function:

<div class="wp-block-ht-ht-note">&lt;div class="wp-block-ht-ht-note">测试&lt;/div></div>

Content retrieved from post body:

<div class="wp-block-ht-ht-note">测试</div>

现象

出现这种报错通常原因是save方法和edit方法结果没有对上。本来是一个挺常见的bug。通常需要简单修改一下就能正常使用了。

但这次有些不太一样。仔细观察报错日志:

text 复制代码
save()方法保存的内容:
<div class="wp-block-ht-ht-note">
<div class="wp-block-ht-ht-note">
测试
</div>
</div>

edit()方法保存的内容:
<div class="wp-block-ht-ht-note">
测试
</div>

也就是save()方法保存了两次{ ...useBlockProps() }

原因

保存了两次,我们要搞清楚是从哪里来的。

第一次的div

这个很好理解,毕竟save方法使用了<div { ...useBlockProps.save() }>。使用这种方式就会解析成<div class="wp-block-ht-ht-note">

第二次的div

剩下的那也就能正常推断出来了:除了save方法使用的,就只可能是{noteContent}中本身的内容了。通过<div class="wp-block-ht-ht-note">&lt;div class="wp-block-ht-ht-note">测试&lt;/div></div>的转义内容也能够推断出,{noteContent}是包含着一个<div class="wp-block-ht-ht-note">

解决方案

知道原因就好解决了,既然保存时就带上了,那save()方法就不需要再添加一次了。

修改save()方法:

js 复制代码
export default function save({ attributes }) {

    const { noteContent } = attributes;

    return (
        <>
            { noteContent }
        </>
    );
}

保存刷新,解决。

相关推荐
Lhuu(重开版1 小时前
html语法
前端·html
小只笨笨狗~1 小时前
css-文字背景渐变色
前端·css·html
Access开发易登软件14 小时前
Access导出带图表的 HTML 报表:技术实现详解
数据库·后端·html·vba·导出·access
顾安r14 小时前
11.8 脚本网页 打砖块max
服务器·前端·html·css3
诚实可靠王大锤18 小时前
WebSocket调试工具(html),用于调试WebSocket链接是否畅通
websocket·网络协议·html
摇滚侠19 小时前
浏览器的打印功能,如果通过HTML5,控制样式
前端·html·html5
黑咩狗夜.cm20 小时前
Aspose.word实现表格每页固定表头、最后一行填满整个页面
开发语言·c#·word
gCode Teacher 格码致知20 小时前
Python教学基础:用Python和openpyxl结合Word模板域写入数据-由Deepseek产生
python·word
程序猿_极客1 天前
【期末网页设计作业】HTML+CSS+JS 香港旅游网站设计与实现 (附源码)
javascript·css·html
一枚前端小能手1 天前
🏷️ HTML 属性参考 - 常用与全局属性的行为、兼容性与最佳实践
前端·javascript·html