我有一个永远不会重新加载页面的js应用程序,因此在导航时我需要完全删除TinyMCE控件,然后我想在导航到需要它的区域时重新初始化.我尝试了这个问题的接受答案,但似乎什么也没做.
tinymce.EditorManager.execCommand('mceRemoveControl',true, editor_id);
Run Code Online (Sandbox Code Playgroud)
和我的具体意见:
//if I throw an alert here, it does get called, so I know it's not null
if (tinyMCE.getInstanceById("main-text"))
tinyMCE.EditorManager.execCommand('mceRemoveControl', true, "main-text");
Run Code Online (Sandbox Code Playgroud)
我也试过了
tinyMCE.remove( tinyMCE.getInstanceById("main-text"));
// AND
tinyMCE.remove( "main-text");
Run Code Online (Sandbox Code Playgroud)
我知道当我在条件中发出警报时,该语句会被执行...我知道这是正确的ID-- API中是否还有其他内容我缺少?这不是jQuery版本.编辑器在删除尝试后仍然存在,如果我通过导航回到具有该表单的状态重新启动它,我甚至会获得具有相同ID的新编辑器.
编辑:下面的解决方案在当前版本3.5b3中不起作用,仅在3.4.9中.有一个'未定义'的错误
以防万一,这是init之后DOM的相关部分.
<textarea id="main-text" style="display: none;" aria-hidden="true"></textarea>
<span id="main-text_parent" class="mceEditor defaultSkin" role="application" aria-labelledby="main-text_voice" style="display: inherit;">
<span id="main-text_voice" class="mceVoiceLabel" style="display:none;">Rich Text Area</span>
<table id="main-text_tbl" class="mceLayout" cellspacing="0" cellpadding="0" role="presentation" style="width: 100%; height: 400px;">
<tbody>
<tr class="mceFirst" role="presentation">
<td class="mceToolbar mceLeft mceFirst mceLast" role="presentation">
<div id="main-text_toolbargroup" aria-labelledby="main-text_toolbargroup_voice" role="group" …Run Code Online (Sandbox Code Playgroud)