百度编辑器二次开发常用手记整理小结

所属分类: 网络编程 / 网页编辑器 阅读数: 467
收藏 0 赞 0 分享
创建自定义编辑器:
复制代码 代码如下:

//引入editor_config.js,editor_api.js,ueditor.css文件,然后在body中创建编辑器实例与父容器
<div id="myEditor"></div>
<script type="text/javascript">
var editorOption = {
toolbars:[['FullScreen', 'Source', 'Undo', 'Redo','Bold']],
autoClearinitialContent:true,
wordCount:false,
};
var editor_a = new baidu.editor.ui.Editor(editorOption);
editor_a.render( 'myEditor' );
</script>

配置弹出工具按钮:
复制代码 代码如下:

//editor_config.js editorui.js文件中找到toolbars labelMap iframeUrlMap btnCmds dialogBtns 五个参数进行配置
//toolbars:工具或下拉框参数,
//labelMap:工具按钮提示信息
//iframeUrlMap:弹出插件URL路径
//btnCmds:工具按钮统一触发命令
//dialogBtns:弹出命令
//注册插件 []传入的是toolbars中的参数
UE.plugins[] = function(){
  ....
  execCommand:function(cmdName,myobject){
    ....
  }
}

配置命令工具按钮:
复制代码 代码如下:

//editor_config.js editorui.js文件中找到toolbars labelMap btnCmds
//注册命令工具按钮 []传入的是toolbars中的参数
UE.commands[] = function(){
  .....
  execCommand:function(){
    .....
  }
}

右键按钮配置:
复制代码 代码如下:

//editor_config.js contextmenu.js文件中找到toolbars labelMap items三个参数进行配置
//命令右键配置
items:
{
  label:"", [右键名字]
  cmdName:"",[toolbars参数中所配置的名字]
  exec:function(){
    this.execCommand("");[toolbars参数中所配置的名字]
  }
}
//注册右键按钮命令
UE.commands[] = function(){
  execCommand:function(){
    .......
  }
}
注:注册右键按钮命令[]中依然是toolbars参数中所配置的名字
//插件右键配置[]传入的参数是toolbars中的参数
items:
{
  label:"",
  cmdName:"",
  exec:function(){
    if(UE.ui[]){
      new UE.ui[](this);
    }
    this.ui._dialogs['...Dialog'].open();
  }
}
//注册右键插件 []传入的参数是toolbars中的参数
UE.plugins[] = function(){
  ....
  execCommand:function(cmdName,myobject){
    ....
  }
}

插件命令配置:
复制代码 代码如下:

UE.plugins[] = function(){
var me = this;
  //注册鼠标和键盘事件
me.addListener('mousedown',_mouseDownEvent);
me.addListener('keydown',function(type,evt){...});
me.addListener('mouseup',function(){});
  //查询当前命令状态
queryCommandState:function(cmdName){}
  //命令执行主体
exeCommand:function(cmdName,myobject){}
  //获取命令执行结果
queryCommandValue:function(cmdName){}
}

插件弹出执行注册:
复制代码 代码如下:

dialog.onok = function(){
editor.execCommand("",""); //两个参数,功能参数,我们自己需要传入的值
dialog.close();
}

一些操作类,实用:
复制代码 代码如下:

//editor.selection.getRange() 查询范围方法
//editor类,此类用于初始化的一些设置,比如获取内容,设置高宽,设置编辑器内容等等。
//domUtils类,此类用于不同帧内dom节点的操作,比如获取父节点,节点属性,文本内容等等。
//browser类,此类用于检测游览器,比如判断IE火狐等。
//EventBase类,此类用基础事件的注册类,比如鼠标,键盘事件等。
//ajax类,此类用于ajax工具类。
//暂时在工作里只用到了上述,代码的组织结构,都还木有研究。


如何给百度编辑器editor扩展

百度编辑器的editor对象中,是百度编辑器所有方法对象,在扩展时,只需要在首页实例中,添加方法。editor.xx = {}。

在任何的页面中editor对象,都可以点出我们在首页中定义的扩展方法。
更多精彩内容其他人还在看

整合ckeditor+ckfinder,解决上传文件路径问题

现在fckeditor已经改名为ckeditor,上传控件也分离为ckfinder,按照说明文档的默认配置会出现上传路径不正确的情况,因为我们的网站可以通过定义默认网站、虚拟目录、以及放在网站的子目录下进行访问
收藏 0 赞 0 分享

在kindEditor中获取当前光标的位置索引的实现代码

一直在用KindEditor,今天要用到光标的位置,然后就gg一下办法,后来发现这东西的编辑区域居然是iframe里面的一个body,不是textarea/input,后来就翻开了他的代码看,发现有个insertHtml
收藏 0 赞 0 分享

KindEditor 4.x 在线编辑器常用方法小结

要修改默认后台程序处理文件,修改plugins(插件文件夹)下的JavaScript内容fileManagerJson改为自己使用程序语言
收藏 0 赞 0 分享

javascript开发随笔3 开发iframe富文本编辑器的一点体会

前段时间有个需求是开发富文本编辑器,这个之前随做过,但看了需求,发现有些地方还需google
收藏 0 赞 0 分享

TinyMCE syntaxhl插入代码后换行的修改方法

上次搞了个整合insert code的TinyMCE编辑器,非常好用。但有一个缺点:每次插入代码后,光标都会停留在pre标记里面,打回车出不来,必须编辑HTML
收藏 0 赞 0 分享

Fckeditor编辑器内容长度限制统计实现方法

Fckeditor是一种大家常用的编辑器,但是他不能像网页表单那样利用document.getelementbyid能获取得到值了,它必须通过 FCKeditorAPI来操作,下面看看Fckeditor内容长度测试
收藏 0 赞 0 分享

PHP中CKEditor和CKFinder配置问题小结

PHP中CKEditor和CKFinder配置问题小结,使用CKEditor和CKFinder编辑器的朋友可以参考下
收藏 0 赞 0 分享

ckeditor的使用和配置方法分享

CKEditor是新一代的FCKeditor,是一个重新开发的版本。CKEditor是全球最优秀的网页在线文字编辑器之一,因其惊人的性能与可扩展性而广泛的被运用于各大网站
收藏 0 赞 0 分享

FCKeditor 2.6.6在ASP中的安装及配置方法分享

FCKeditor目前的最新版本是2.6.6,在网上搜索此版本的配置方法,发现很少有asp的配置方法,以下就把自己的一些配置经验分享给有需要的你。
收藏 0 赞 0 分享

FCKeditor 2.6.5 ASP环境安装配置使用说明

今天用到在线编辑器在asp环境下上传竟然无效。找了好久才找到这介绍,现备份于此,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多