gpt4 book ai didi

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

转载 作者:搜寻专家 更新时间:2023-11-01 04:42:47 25 4
gpt4 key购买 nike

以下方法:

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 调用(通过其他一些解决方法),如果那不是一个选项,我想知道为什么。

我担心这可能不是这种情况下最干净的解决方案。

最佳答案

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

可能在加载时执行此函数会使问题消失。如果是这种情况,那么您必须弄清楚问题发生时发生了什么,也许可以在 Firebug 中进行配置文件 session 。

关于javascript - setTimeout(f,0) 等效?为什么它解决了跨浏览器问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8507666/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com