繁体   English   中英

如何将自定义按钮和对话框迁移到 TinyMCE 5

[英]How to migrate custom buttons and dialogs to TinyMCE 5

我有一个第三方 Bootstrap 插件(可能是 EOL),它向工具栏添加了按钮,然后打开了一个对话框,我可以从中选择 Bootstrap 元素以添加到内容中。

它使用了以下代码:

var insertBtn = tinymce.ui.Factory.create({
    type: elType,
    classes: elClass,
    text: bsText['button'],
    icon: 'icon-btn',
    name: 'insertBtnBtn',
    tooltip: bsTip['button'],
    onclick: function() {
        showDialog('bootstrap-btn.php', 'Add button', 580, 'bsBtn');
    }
});
bsItems.push(insertBtn);

但它说 Factory 是未定义的,或者 create 是一个不存在的函数。 我可以用什么来完成这项工作,显示按钮以及单击时显示对话框? 我已经更新了以下代码来查看 bsItems:

editor.ui.registry.addButton('bootstrap', {
    type: 'buttongroup',
    classes: 'bs-btn',
    items: bsItems
});

我尝试了其他几种可能性来找到 create 函数:

editor.ui.registry.create()
editor.ui.Factory.create()
editor.ui.create()
tinymce.ui.registry.create()
tinymce.ui.Factory.create()
tinymce.ui.create()

一切都无济于事

在第 5 版中,TinyMCE 使用了新的 UI 框架。 为版本 4.x 编写的提供自定义 UI 控制元素的第三方插件可能不适用于版本 5。

如此 GitHub 问题线程中所述tinymce.ui.Factory已被弃用且不会重新实现,因此不再可能创建控制工厂。

添加按钮等 UI 元素的方法也从 v4 更改为 v5。 官方迁移指南详细介绍了这些方法的新位置和配置签名。

tl;dr 这个特定的插件可能不适用于 v5 的新 UI 框架,但仍然有使用新系统自定义 UI 的方法。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM