[转载] 关于ckEditor 的一些小知识

本文介绍了一个关于CKEditor中使用setData方法时遇到的问题及其解决方案。原作者尝试通过循环方式向编辑器插入数据,但由于setData方法的异步特性导致循环无法完全执行。通过调整代码逻辑,将所有要插入的内容拼接成一个字符串后再调用setData方法,成功解决了这一问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

http://jiangzhenghua.iteye.com/blog/793282


今天写了一段代码:目的是向CKEditor中插入数据如下:

Js代码  收藏代码
  1. function insertSrc(srcArray){  
  2.             var i=0  
  3.             for (i=0;i<=srcArray.length;i++)  
  4.             {  
  5.                 var oEditor = CKEDITOR.instances.articleContent;  
  6.                 var editorData_old = oEditor.getData() ;  
  7.                 var editorData_new = editorData_old.substring(0,editorData_old.indexOf('</head>'))  
  8.                 +   
  9.                 srcArray[i]  
  10.                 +  editorData_old.substring(editorData_old.indexOf('</head>')) ;  
  11.                 oEditor.setData(editorData_new) ;  
  12.             }               
  13.         }  

 

经过调试发现该函数执行有问题,循环中后几个循环不能执行。原因就是CKEDITOR中的setData()方法是ajax异步的。

最终改写代码为:

Js代码  收藏代码
  1. function insertSrc(srcArray){  
  2.             var oEditor = CKEDITOR.instances.articleContent;  
  3.             var editorData_old = oEditor.getData() ;  
  4.             var old_begin = editorData_old.substring(0,editorData_old.indexOf('</head>')) ;  
  5.             var old_end =  editorData_old.substring(editorData_old.indexOf('</head>')) ;  
  6.             var insertData = '' ;  
  7.             for(var i=0;i<srcArray.length;i++)  
  8.             {  
  9.                 insertData = insertData + srcArray[i] ;  
  10.             }  
  11.             var editorData_new =old_begin + insertData + old_end ;  
  12.             oEditor.setData(editorData_new) ;  
  13.         }  

 

注:我们应该知道CKEditor中getData()方法是正常的方法,而setData()方法是异步方法。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值