如何从tinymce上下文菜单插件调用thickbox?

发布于 2024-10-08 07:55:02 字数 316 浏览 6 评论 0原文

如何在tinymce的上下文菜单中添加项目。我需要从tinymce的上下文菜单选择中打开一个thickbox

    var url = "upload.php?keepThis=true&TB_iframe=1&width=1000&height=400&model=true";
    tb_show("Edit Image", url);

我可以使用上面的代码调用thickbox。我需要在上下文菜单插件中重新编码。帮助我

How to add item in contextmenu of tinymce. I need to open a thickbox from contextmenu selection of tinymce

    var url = "upload.php?keepThis=true&TB_iframe=1&width=1000&height=400&model=true";
    tb_show("Edit Image", url);

I can call thickbox with above codes. Where i need to recode in contextmenu plugin. Help me

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

帝王念 2024-10-15 07:55:02

好的,在这种情况下,您需要加载上下文菜单插件(在加载自定义插件之前执行此操作!)

plugins: '...,contextmenu,....,customcontextmenu,...',

这是自己的上下文菜单插件的完整示例代码。您需要将此代码放在插件目录的名为“contextmenu”的子目录中名为“editor_plugin.js”的文件(以及名为“editor_plugin_src.js”的文件)中。

(function() {

  tinymce.PluginManager.requireLangPack('customcontextmenu');

  tinymce.create('tinymce.plugins.customcontextmenu', {

    init : function(ed, url) {
        ed.addCommand('custom_option', function() {
            // do what you want here!!!
        });

// we need the real contextmenu in order to make this work
if (ed && ed.plugins.contextmenu) {

        // contextmenu gets called - this is what we do
    ed.plugins.contextmenu.onContextMenu.add(function(th, m, e, col) {

        // remove all options from standard contextmenu
        m.removeAll();

        // only if selected node is an image do this
        if (typeof e !== "undefined" && e.nodeName.toLowerCase() == 'img'){

            th._menu.add({
                title: 'Option 1',
                icon: 'option1',  // you might need to specify an image here
                cmd: 'custom_option' // call command custom_option
            });

            m.addSeparator();

                        // Second option
            //m.add({
            //  title: 'Option 2',
            //  icon: 'option2',
            //  cmd: 'custom_option2'
            //});
        }
                else {
                   // you might want to hinder the display of the contextmenu in all other cases
                   // or present other options....
                }
    });
    }
   });
},

  // Register plugin
  tinymce.PluginManager.add('customcontextmenu', tinymce.plugins.customcontextmenu);


})();

确保括号设置正确(我必须复制/粘贴并删除部分代码,因此可能会丢失括号)。

Ok, in that case you need to load the contextmenu plugin (do this before you load your custom plugin!)

plugins: '...,contextmenu,....,customcontextmenu,...',

Here is the full sample code for an own contextmenu plugin. You need to have this code inside a file called 'editor_plugin.js' (and a file called 'editor_plugin_src.js') in a subdirectory named 'contextmenu' of the plugins directory.

(function() {

  tinymce.PluginManager.requireLangPack('customcontextmenu');

  tinymce.create('tinymce.plugins.customcontextmenu', {

    init : function(ed, url) {
        ed.addCommand('custom_option', function() {
            // do what you want here!!!
        });

// we need the real contextmenu in order to make this work
if (ed && ed.plugins.contextmenu) {

        // contextmenu gets called - this is what we do
    ed.plugins.contextmenu.onContextMenu.add(function(th, m, e, col) {

        // remove all options from standard contextmenu
        m.removeAll();

        // only if selected node is an image do this
        if (typeof e !== "undefined" && e.nodeName.toLowerCase() == 'img'){

            th._menu.add({
                title: 'Option 1',
                icon: 'option1',  // you might need to specify an image here
                cmd: 'custom_option' // call command custom_option
            });

            m.addSeparator();

                        // Second option
            //m.add({
            //  title: 'Option 2',
            //  icon: 'option2',
            //  cmd: 'custom_option2'
            //});
        }
                else {
                   // you might want to hinder the display of the contextmenu in all other cases
                   // or present other options....
                }
    });
    }
   });
},

  // Register plugin
  tinymce.PluginManager.add('customcontextmenu', tinymce.plugins.customcontextmenu);


})();

Make sure the brackets are set right (i had to copy/paste and delete parts of the code so there might brackets be missing).

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文