您好,匿名用户

angular-ueditor使用中,插入图片,加载完成后不更新angularmodel的问题;

0 投票

使用百度编辑器时,插入图片初始为loading图,载入成功后才显示上传的图片,
插入图片后不做任何修改时,控制器中的model是这样的

<p><img class="loadingclass" id="loading_iwwwjn6l" src="http://d.com:12080/Public/backend/lib/ueditor/themes/default/images/spacer.gif" title="正在上传..."/></p>

即使图片已经上传成功,在编辑器已经显示出来了,但是model中还是没有得到修改,只有再修改点其他东西,触发ueditor的changecontent事件后,才会修改model;
udeitor指令中的监听changecontent:

_self.editor.addListener("contentChange", function() {
    ctrl.$setViewValue(_self.editor.getContent());
    if (!_updateByRender) {
      if (!$S.$$phase) {
        $S.$apply();
      }
    }
    _updateByRender = false;
  });

查看ueditor源码:

function callback(){
    try{
        var link, json, loader,
            body = (iframe.contentDocument || iframe.contentWindow.document).body,
            result = body.innerText || body.textContent || '';
        json = (new Function("return " + result))();
        link = me.options.imageUrlPrefix + json.url;
        if(json.state == 'SUCCESS' && json.url) {
            loader = me.document.getElementById(loadingId);
            loader.setAttribute('src', link);
            loader.setAttribute('_src', link);
            loader.setAttribute('title', json.title || '');
            loader.setAttribute('alt', json.original || '');
            loader.removeAttribute('id');
            domUtils.removeClasses(loader, 'loadingclass');
        } else {
            showErrorLoader && showErrorLoader(json.state);
        }
    }catch(er){
        showErrorLoader && showErrorLoader(me.getLang('simpleupload.loadError'));
    }
    form.reset();
    domUtils.un(iframe, 'load', callback);
}

图片上传成功后,直接将原来loading图的src修改成返回的链接,但是这样却没有出发angular的$apply,实际上应该说是没有出发changecontent,导致model没有被更新;

求问大神,如何让angular model 在修改img src属性时得到更新呢?
这问题困扰了很久了,之前看到博客有个大兄弟给changecontent里面加了个延迟

 _self.editor.addListener("contentChange", function() {  
    //此处设置一个延迟,防止图片还没有从服务器返回,从而获取到的是loading图片  
    setTimeout(function() {  
      ctrl.$setViewValue(_self.editor.getContent());  
      if (!_updateByRender) {  
        if (!$S.$$phase) {  
          $S.$apply();  
        }  
      }  
      _updateByRender = false;  
    }, 50)  
  });  

但是治标不治本,如果我的图片在50ms之后才载入,也是没有用的。。。。
找不到contentchange的事件代码。

用户头像 提问 2017年 5月22日 @ Garen 下士 (979 威望)
分享到:

1个回答

0 投票
用户头像 回复 11月16日 @ king 列兵 (91 威望)
提一个问题:

相关问题

0 投票
1 回复 48 阅读
用户头像 提问 2017年 2月22日 @ Riven 中士 (1,084 威望)
0 投票
0 回复 80 阅读
用户头像 提问 2014年 1月5日 @ Ezreal 中士 (1,081 威望)
0 投票
0 回复 84 阅读
0 投票
1 回复 51 阅读
用户头像 提问 2017年 2月28日 @ Cancer 下士 (906 威望)
0 投票
1 回复 146 阅读
用户头像 提问 2017年 2月19日 @ Demeter 下士 (578 威望)

欢迎来到随意问技术百科, 这是一个面向专业开发者的IT问答网站,提供途径助开发者查找IT技术方案,解决程序bug和网站运维难题等。
温馨提示:本网站禁止用户发布与IT技术无关的、粗浅的、毫无意义的或者违法国家法规的等不合理内容,谢谢支持。

欢迎访问随意问技术百科,为了给您提供更好的服务,请及时反馈您的意见。
...