根据用户选择的列表在CKEditor中动态添加上下文菜单项

时间:2015-05-21 15:19:26

标签: javascript html ckeditor

使用CKEditor插件,我尝试根据用户从DataTable对象中选择的项目添加上下文菜单项。菜单项显示就好了。添加的第一个菜单项当前时间/日期有效。但是当点击For循环添加的任何项目时,它们都会执行最后一个命令。此外,循环添加的菜单项应该在他们自己的组中,我认为它们会自动放在它们和当前时间/日期命令之间。

cmd 是要添加的命令的名称。 menuList 是上下文菜单项的数组。 menuDetails 是命令详细信息的数组(标签,命令,组,顺序)

以下是添加项目的JavaScript:

function InitRTFContext(editor) {           
        if ( editor.contextMenu ) {
            var cmd;
            var menuList = new Object();
            var menuCommand = new Object();
            var menuDetails = new Object();
            var i = 2;
            cmd = "cmdTimeAndDate";
            editor.addMenuGroup( 'CommonGroup' );               
            editor.addCommand(cmd, { exec : function( editor ) { editor.insertText('[[Now]]'); }});
            menuDetails["label"] ='Current Time/Date';
            menuDetails["command"] = cmd;
            menuDetails["group"] = 'CommonGroup';
            menuDetails["order"] = 1;
            menuCommand[cmd] = menuDetails;     
            menuList[cmd] = CKEDITOR.TRISTATE_OFF;


            editor.addMenuGroup('DynamicFields');
            dtChosen.rows().data().each(function (row) {
                if (row.QuestionTypeID != 0 && row.QuestionTypeID != 4 && row.Text != 'Text Block') {
                    i++;                        

                    cmd = "Q_" + row.WebFormTemplateQuestionID + "_" + row.Text;
                    cmd = cmd.replace(/\s/g, '');

                    /* This section is not working */
                    editor.addCommand(cmd, { exec : function( editor ) { editor.insertText('[[' + cmd + ']]'); }});                     
                    /* This section is not working */

                    menuDetails = new Object();
                    menuDetails["label"] = row.Text;
                    menuDetails["command"] = cmd;
                    menuDetails["group"] = 'DynamicFields'; 
                    menuDetails["order"] = i;
                    menuCommand[cmd] = menuDetails;
                    menuList[cmd] = CKEDITOR.TRISTATE_OFF;                      
                }                   
            });

            editor.addMenuItems(menuCommand);
            editor.contextMenu.addListener( function( element, selection ) {
                return menuList;
            });
        }
        else {
            alert('Error loading RTF Context Menu.');
        }
    }

这会创建: (没有足够的代表发布图片,所以输入它)

  

粘贴

           

当前时间/日期

     

客户名称

     

客户电话

     

客户电邮

     

...

点击当前时间/日期后的所有命令都会打印用于客户电子邮件的命令。那么,我错过了什么?

1 个答案:

答案 0 :(得分:0)

这里的问题是'cmd'。您在方法中使用它,但它在父范围内声明。如果您使用'var'在循环内声明它,它将正常工作。