等待TinyMCE加载

时间:2011-09-13 21:12:06

标签: jquery tinymce

我依次拥有这两行代码。

tinymce.execCommand('mceAddControl',true,'email_body');
tinyMCE.activeEditor.setContent(data.tplCustom.htmltemplate);

第二行尝试在完成注释之前设置内容。我认为原因是我得到“tinyMCE.activeEditor为空”错误。

有没有办法等到它加载?感谢

2 个答案:

答案 0 :(得分:54)

TinyMCE的第4版使用稍微不同的事件绑定方法。

版本3

// v3.x
tinymce.init({
    setup : function(ed) {
        ed.onInit.add(function(ed) {
            console.debug('Editor is done: ' + ed.id);
        });
    }
});

版本4

// v4.x
tinymce.init({
    setup: function (ed) {
        ed.on('init', function(args) {
            console.debug(args.target.id);
        });
    }
});

参考: http://www.tinymce.com/wiki.php/API3:event.tinymce.Editor.onInit http://www.tinymce.com/wiki.php/Tutorial:Migration_guide_from_3.x

答案 1 :(得分:10)

如果您无法访问tinymce.init({...})声明(例如 WordPress ),您还可以使用addeditor事件:

  /// Fires when an editor is added to the EditorManager collection.
  tinymce.on('addeditor', function( event ) {
    var editor = event.editor;
    var $textarea = $('#' + editor.id);
    console.log($textarea.val());
  }, true );

TinyMCE 'addeditor' event documentation