FCK的高级功能和常见问题的解决方法
2010-01-26 17:32
309 查看
FCKeditor是一个专门使用在网页上属于开放源代码的所见即所得文字编辑器。它志于轻量化,不需要太复杂的安装步骤即可使用。它可和PHP、JavaScript、ASP、ASP.NET、ColdFusion、Java、以及ABAP等不同的编程语言相结合。FCK的配置和使用都很简单,但是默认的配置不能满足所有的需求,所以我们需要了解一些FCK的高级功能。
获取FCK的实例
FCKeditorAPI是FCKeditor加载后注册的一个全局对象,利用它我们就可以完成对编辑器的各种操作。
在当前页获得 FCK 编辑器实例:
var Editor = FCKeditorAPI.GetInstance('InstanceName');
从 FCK 编辑器的弹出窗口中获得 FCK 编辑器实例:
var Editor = window.parent.InnerDialogLoaded().FCK;
从框架页面的子框架中获得其它子框架的 FCK 编辑器实例:
var Editor = window.FrameName.FCKeditorAPI.GetInstance('InstanceName');
从页面弹出窗口中获得父窗口的 FCK 编辑器实例:
var Editor = opener.FCKeditorAPI.GetInstance('InstanceName');
FCK获取焦点
获取焦点是否在FCK中:
oEditor.HasFocus
FCK获取焦点:
oEditor.Focus();//获取焦点
获取和设置FCK的内容
获得 FCK 编辑器的内容:
oEditor.GetXHTML(formatted); // formatted 为:true|false,表示是否按HTML格式取出。
设置 FCK 编辑器的内容:
oEditor.SetHTML("content", false); // 第二个参数为:true|false,是否以所见即所得方式设置其内容。
插入内容到 FCK 编辑器:
oEditor.InsertHtml("html"); // "html"为HTML文本
检查 FCK 编辑器内容是否发生变化:
oEditor.IsDirty();
1 // 获取编辑器中HTML内容
2 function getEditorHTMLContents(EditorName) {
3 var oEditor = FCKeditorAPI.GetInstance(EditorName);
4 return(oEditor.GetXHTML(true));
5 }
6
7 // 获取编辑器中文字内容
8 function getEditorTextContents(EditorName) {
9 var oEditor = FCKeditorAPI.GetInstance(EditorName);
10 return(oEditor.EditorDocument.body.innerText);
11 }
12
13 // 设置编辑器中内容
14 function SetEditorContents(EditorName, ContentStr) {
15 var oEditor = FCKeditorAPI.GetInstance(EditorName) ;
16 oEditor.SetHTML(ContentStr) ;
17 }
18
FCK的事件处理
FCK定义有OnComplete,OnBlur和OnFocus等事件,这样就可以使用事件的处理函数完成相应的处理。
FCK添加事件处理函数的方法是:fckInstance.Events.AttachEvent( EventName, function)
代码
//FCKeditor加载完成后做处理的方法
function FCKeditor_OnComplete( editorInstance )
{
editorInstance.Events.AttachEvent( 'OnBlur' , FCKeditor_OnBlur ) ;
editorInstance.Events.AttachEvent( 'OnFocus', FCKeditor_OnFocus ) ;
}
function FCKeditor_OnBlur( editorInstance )
{
//失去焦点收起工具栏
editorInstance.ToolbarSet.Collapse() ;
}
function FCKeditor_OnFocus( editorInstance )
{
editorInstance.ToolbarSet.Expand() ;
}
获取FCK的实例
FCKeditorAPI是FCKeditor加载后注册的一个全局对象,利用它我们就可以完成对编辑器的各种操作。
在当前页获得 FCK 编辑器实例:
var Editor = FCKeditorAPI.GetInstance('InstanceName');
从 FCK 编辑器的弹出窗口中获得 FCK 编辑器实例:
var Editor = window.parent.InnerDialogLoaded().FCK;
从框架页面的子框架中获得其它子框架的 FCK 编辑器实例:
var Editor = window.FrameName.FCKeditorAPI.GetInstance('InstanceName');
从页面弹出窗口中获得父窗口的 FCK 编辑器实例:
var Editor = opener.FCKeditorAPI.GetInstance('InstanceName');
FCK获取焦点
获取焦点是否在FCK中:
oEditor.HasFocus
FCK获取焦点:
oEditor.Focus();//获取焦点
获取和设置FCK的内容
获得 FCK 编辑器的内容:
oEditor.GetXHTML(formatted); // formatted 为:true|false,表示是否按HTML格式取出。
设置 FCK 编辑器的内容:
oEditor.SetHTML("content", false); // 第二个参数为:true|false,是否以所见即所得方式设置其内容。
插入内容到 FCK 编辑器:
oEditor.InsertHtml("html"); // "html"为HTML文本
检查 FCK 编辑器内容是否发生变化:
oEditor.IsDirty();
1 // 获取编辑器中HTML内容
2 function getEditorHTMLContents(EditorName) {
3 var oEditor = FCKeditorAPI.GetInstance(EditorName);
4 return(oEditor.GetXHTML(true));
5 }
6
7 // 获取编辑器中文字内容
8 function getEditorTextContents(EditorName) {
9 var oEditor = FCKeditorAPI.GetInstance(EditorName);
10 return(oEditor.EditorDocument.body.innerText);
11 }
12
13 // 设置编辑器中内容
14 function SetEditorContents(EditorName, ContentStr) {
15 var oEditor = FCKeditorAPI.GetInstance(EditorName) ;
16 oEditor.SetHTML(ContentStr) ;
17 }
18
FCK的事件处理
FCK定义有OnComplete,OnBlur和OnFocus等事件,这样就可以使用事件的处理函数完成相应的处理。
FCK添加事件处理函数的方法是:fckInstance.Events.AttachEvent( EventName, function)
代码
//FCKeditor加载完成后做处理的方法
function FCKeditor_OnComplete( editorInstance )
{
editorInstance.Events.AttachEvent( 'OnBlur' , FCKeditor_OnBlur ) ;
editorInstance.Events.AttachEvent( 'OnFocus', FCKeditor_OnFocus ) ;
}
function FCKeditor_OnBlur( editorInstance )
{
//失去焦点收起工具栏
editorInstance.ToolbarSet.Collapse() ;
}
function FCKeditor_OnFocus( editorInstance )
{
editorInstance.ToolbarSet.Expand() ;
}
相关文章推荐
- FCKEDITOR 的高级功能和常见问题的解决方法
- Java-jdk的安装,Tomcat服务器的安装,在eclipse中添加JavaEE插件常见问题以及解决方法,步骤
- WSS&MOSS常见问题及解决方法[不断更新]
- 常见编译问题解决方法集
- DevExpress DateEdit 5 常见问题解决方法
- MyBatis 参数类型为String时常见问题及解决方法
- 常见表单重复提交问题整理及解决方法
- PHP开发中常见的安全问题详解和解决方法
- centos7安装oracle中遇到的常见问题解决方法
- WF 自定义活动开发常见问题(进入第二个流程状态,数据传递失败的解决方法)
- Genymotion常见问题的解决方法
- IAR软件的Go to Definition of 功能问题的解决方法
- 安装rpm报错问题常见解决方法
- Android开发环境搭建及常见问题解决方法
- 打印机常见问题与解决方法
- Extjs Column布局常见问题及解决方法
- Windows 7系统安装常见问题解决方法
- Linux下安装 TestLink常见问题解决方法
- jmeter 常见问题 及解决方法
- OpenStack安装部署管理中常见问题解决方法