wangEditor版本升级导致的一些问题

系统早期使用的wangEditor的4.x版本,录入了很多数据。之后升级了5.x版本。 近期用户编辑早先4.x时期录入的数据,直接报错。定位错误是调用editor.setHtml(content);报错。

问题1: # Cannot read properties of null (reading 'length')

官方方案#4933

出问题数据如下:

js 复制代码
<h3 id=\"prnoj\">4.标题</h3>
<a  href=\"https://github.com/wangeditor-team/wangEditor/issues/4933\"   target=\"_blank\">https://github.com/wangeditor-team/wangEditor/issues/4933
    </a><br/>

页面崩溃,控制台打印错误日志如下:

其中的a标签替换为img标签也报同样的错

解决方案

a或者img标签外层嵌套一层p标签

js 复制代码
<h3 id=\"prnoj\">4.标题</h3><p><a href=\"https://github.com/wangeditor-team/wangEditor/issues/4933\" target=\"_blank\">https://github.com/wangeditor-team/wangEditor/issues/4933</a></p><br/>

问题2: 图片不展示

旧数据如下:

js 复制代码
<h3>标题</h3>
<div><img src=\"https://images.pexels.com/photos/19117864/pexels-photo-19117864.jpeg\" contenteditable=\"false\"/></div>

现象是:只有标题展示,图片不展示

解决方案

将img标签使用p标签包裹,只能是P标签,如下

html 复制代码
<h3>标题</h3>
<p><img src=\"https://images.pexels.com/photos/19117864/pexels-photo-19117864.jpeg\" contenteditable=\"false\"/></p>

其实在5.0输入一个图片,自动生成的代码就是p标签包裹img标签的格式

终极解决方案

如果想要4.0的数据展示5.0的效果。需要在出问题的地方都包裹一个P标签

如果不需要数据复原展示,只需要防止页面崩溃,直接try...catch 一下

js 复制代码
      try {
        editor.setHtml(content);
      } catch(e) {
        editor.setHtml(`<p>${content}</p>`);
      }
相关推荐
鸡吃丸子24 分钟前
常见的实时通信技术(轮询、sse、websocket、webhooks)
前端·websocket·状态模式
胡斌附体1 小时前
vue添加loading后修复页面渲染问题
前端·javascript·vue.js·渲染·v-if·异步加载
酷爱码2 小时前
css中的 vertical-align与line-height作用详解
前端·css
沐土Arvin2 小时前
深入理解 requestIdleCallback:浏览器空闲时段的性能优化利器
开发语言·前端·javascript·设计模式·html
专注VB编程开发20年2 小时前
VB.NET关于接口实现与简化设计的分析,封装其他类
java·前端·数据库
小妖6662 小时前
css 中 content: “\e6d0“ 怎么变成图标的?
前端·css
L耀早睡3 小时前
mapreduce打包运行
大数据·前端·spark·mapreduce
HouGISer3 小时前
副业小程序YUERGS,从开发到变现
前端·小程序
outstanding木槿3 小时前
react中安装依赖时的问题 【集合】
前端·javascript·react.js·node.js
霸王蟹4 小时前
React中useState中更新是同步的还是异步的?
前端·javascript·笔记·学习·react.js·前端框架