setTimeout(f,0)等价?为什么它解决了跨浏览器问题?

时间:2011-12-14 16:07:08

标签: javascript jquery ajax model-view-controller tinymce

以下方法:

Init: function (selector, settings)
{
    setTimeout(function()
    {
        var s =
        {
            width: '100%',
            script_url: '/Content/Scripts/tiny_mce/tiny_mce.js',
            theme: "advanced",
            plugins: "autolink,lists,pagebreak,style,layer,table,paste,directionality,noneditable,visualchars,xhtmlxtras,template",
            theme_advanced_buttons1: "fontselect,fontsizeselect,|,bold,italic,underline,forecolor,backcolor,|,justifyleft,justifycenter,justifyright,justifyfull,|,bullist,numlist",
            theme_advanced_buttons2: "",
            theme_advanced_buttons3: "",
            theme_advanced_buttons4: "",
            theme_advanced_more_colors: false,
            theme_advanced_toolbar_location: "top",
            theme_advanced_toolbar_align: "left",
            theme_advanced_statusbar_location: "none",
            theme_advanced_resizing: false,
            convert_urls: !!$(selector).data("richEditor-ConvertUrls") // by default we don't convert urls
        };
        $.extend(s, settings);
        $(selector).tinymce(s);
    },0);
}

适用于所有浏览器, 出于某种原因,我需要对firefox进行setTimeout(f,0)调用,这个方法是在MVC上的ajax部分加载上调用的,没有这个调用,编辑器挂起在firefox上并且页面中断(点击最常见的异常结果)而不是)。随着电话,一切都很完美。

我想知道如何避免这个setTimeout调用(通过其他一些解决方法),如果这不是一个选项,我想知道原因。

我很害怕这可能不是这种情况下最干净的解决方案。

1 个答案:

答案 0 :(得分:0)

这肯定是一个时间问题。 在DOMContentLoaded上是否还有其他事情发生,也许tinyMCE或其他脚本也在该事件上运行? 或者加载了一个执行document.write()的脚本?

可能在加载时执行此功能会使问题消失。 如果是这种情况,你必须弄清楚问题发生时会发生什么,也许在Firebug中进行一次配置文件会话。