FCK 编辑器焦点问题
程序员文章站
2022-06-16 19:46:30
第一个问题:廷时处理 在页面刚加载的时候对fck赋值,比如在信息列表中选中一条信息进行查看或修改的时候,信息添加的时候用fck编辑的,加载页面的时候会加载fck编辑器,此时...
第一个问题:廷时处理
在页面刚加载的时候对fck赋值,比如在信息列表中选中一条信息进行查看或修改的时候,信息添加的时候用fck编辑的,加载页面的时候会加载fck编辑器,此时会报出一个错误:"fckeditorapi undefined",这是为什么呢,因为页面加载对fckeditorapi 赋值时fckeditorapi 还没创建好,所以才会出现这个错误。那如何解决呢?
我们做一个廷时处理就可以了:
//id:控件id,data:对控件赋值的内容
function setdata(id,data) {
if (typeof fckeditorapi == "undefined" || !fckeditorapi.getinstance(id).editingarea) {
settimeout(function() { setdata(id,data); }, 500);
return;
}
fckeditorapi.getinstance(id).editordocument.body.innerhtml = data;
settimeout(function() { fckeditorapi.getinstance(id).focus(); }, 100);
}
这样就ok了,>.<
第二个地方:对dom对象进行赋值
赋值的时候我们一般用fckeditorapi.getinstance("控件id").sethtml("赋值字符串")来进行赋值,这样也是正确的,但在页面加载的时候这样赋值是不行了,
如果这样赋值你会发现鼠标焦点的控制就有问题了,获取焦点也获取不到,这个时候就要用另一种赋值方式了,对控件的dom对象进行赋值:
fckeditorapi.getinstance(“控件id”).editordocument.body.innerhtml = “赋值字符串”;
这样赋值焦点就恢复正常了。
碰到这个问题的时候也郁闷了好久,希望对使用fck的朋友对遇到这样的问题有点帮助。
在页面刚加载的时候对fck赋值,比如在信息列表中选中一条信息进行查看或修改的时候,信息添加的时候用fck编辑的,加载页面的时候会加载fck编辑器,此时会报出一个错误:"fckeditorapi undefined",这是为什么呢,因为页面加载对fckeditorapi 赋值时fckeditorapi 还没创建好,所以才会出现这个错误。那如何解决呢?
我们做一个廷时处理就可以了:
//id:控件id,data:对控件赋值的内容
function setdata(id,data) {
if (typeof fckeditorapi == "undefined" || !fckeditorapi.getinstance(id).editingarea) {
settimeout(function() { setdata(id,data); }, 500);
return;
}
fckeditorapi.getinstance(id).editordocument.body.innerhtml = data;
settimeout(function() { fckeditorapi.getinstance(id).focus(); }, 100);
}
这样就ok了,>.<
第二个地方:对dom对象进行赋值
赋值的时候我们一般用fckeditorapi.getinstance("控件id").sethtml("赋值字符串")来进行赋值,这样也是正确的,但在页面加载的时候这样赋值是不行了,
如果这样赋值你会发现鼠标焦点的控制就有问题了,获取焦点也获取不到,这个时候就要用另一种赋值方式了,对控件的dom对象进行赋值:
fckeditorapi.getinstance(“控件id”).editordocument.body.innerhtml = “赋值字符串”;
这样赋值焦点就恢复正常了。
碰到这个问题的时候也郁闷了好久,希望对使用fck的朋友对遇到这样的问题有点帮助。