破解因为异步执行而致使的JS插件未加载就使用的问题

相关组件版本:avalon 1.3.6ajax

这个问题一般会在如下情景出现:后端

页面一加载完就要利用JS动态操纵页面的DOM元素、为各种插件赋初值等。api

以ueditor为例,以往,配合后端渲染模板,直接就把初始的值输出到页面,ueditor天然就获取到初始值了;但改成先后端彻底分离后,初始值须要依赖ajax读取api得到,而后再调用ueditor的setContent()方法进行赋值,而ueditor的实例化和初始值的获取这两个操做是异步执行的(固然也能够写成同步执行,利用ueditor的ready()方法便可,但整体来讲不太灵活),这样就形成了一个不稳定的因素:到底在赋初值的时候,ueditor实例化好了没有呢?异步

为此,我思索后,得出以下方案:插件

var ue = UE.getEditor('content_editor');

function article_create_getFirstData() {
  if(typeof(ue) == "object") {
    initUeditor();
  } else {
    setTimeout('article_create_getFirstData()', 500);
  }
}
article_create_getFirstData();

其整体思路是,利用typeof判断预设变量是否已为object(即已实例化),若否,则定时从新进行判断,直到实例化成功后,进行赋初值的操做。code

相关文章
相关标签/搜索