使用jQuery按需加载TinyMCE

4
这是我的脚本:
$.ajaxSetup({async: false});
$.getScript('http://www.mydomain.com/dev/js/tinymce/tiny_mce.js', function(){
    tinyMCE.init({
        document_base_url : "http://www.mydomain.com/dev/js/tinymce/",
        [...],
    });
});
$.ajaxSetup({async: true});

它成功加载了tiny_mce.js,但当在回调中初始化tinymce时,tinymce使用不正确的路径加载了以下2个脚本:

http://www.mydomain.com/dev//langs/en.js
http://www.mydomain.com/dev//themes/advanced/editor_template.js

即使我使用document_base_url或不使用它,tinymce仍然加载上述路径。

你如何准确地调用回调函数? - Thariama
阅读此处:http://tinymce.moxiecode.com/tryit/jquery_version.php - DJafari
2个回答

6

我也遇到了这个问题,在一天的工作后,我找到了一个解决方案,只需在你的tinymce.init()方法之前添加以下代码:

 tinymce.dom.Event.domLoaded = true;

这对我很有用,希望它也能帮到你。
更多详细信息请参阅:加载JS动态时,TinyMCE无法被初始化

6
我按照这里写的方法解决了问题:http://tinymce.moxiecode.com/forum/viewtopic.php?pid=23065#p23065 现在我的通过jQuery动态加载tinyMCE的脚本如下:
// JS_FOLDER = "http://mydomain.com/js"
function initTinyMCE(JS_FOLDER, selector)
{
    var path = JS_FOLDER + '/GlobalUI/tinymce';

    if (selector == undefined) selector = 'mceEditor';
    var initFunct = function() {
        tinyMCE.baseURL = path + '/jscripts/tiny_mce/'; // THE IMPORTANT LINE
        tinyMCE.init({
            mode: "specific_textareas",
            editor_selector: selector,
            width : "700px",
            theme: "advanced",

            theme_advanced_buttons1 : "bold,italic,underline,strikethrough,|,undo,redo,|,bullist,numlist,|,justifyleft,justifycenter,justifyright,justifyfull,|,styleselect,formatselect,fontselect,fontsizeselect,forecolor,backcolor",
            theme_advanced_buttons2 : "",
            theme_advanced_buttons3 : "",
            theme_advanced_buttons4 : "",
            theme_advanced_resizing : true,

            // Example content CSS (should be your site CSS)
            content_css : path + "/css/custom_css.css"
        });
    }

    if(typeof tinyMCE == "undefined") {
        $.getScript(path + '/jscripts/tiny_mce/tiny_mce_src.js', function() {
            initFunct();
        });
    } else {
        initFunct();
    }         

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接