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

时间:2023-10-22 20:28:33 

创建自定义编辑器:


//引入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对象,都可以点出我们在首页中定义的扩展方法。

标签:百度编辑器,二次开发
0
投稿

猜你喜欢

  • SQLServer2008存储过程实现数据插入与更新

    2024-01-19 06:01:21
  • PyCharm关闭碍眼的波浪线图文详解

    2023-07-27 08:47:53
  • asp.net mvc 从数据库中读取图片的实现代码

    2024-01-19 14:51:09
  • MySQL利用procedure analyse()函数优化表结构

    2024-01-17 14:51:00
  • 解决hive中导入text文件遇到的坑

    2023-06-30 16:28:26
  • JavaScript前端学算法题解LeetCode最大重复子字符串

    2024-05-21 10:21:00
  • 关闭窗口时保存数据的办法

    2009-02-19 13:39:00
  • 方便和实用

    2009-02-02 10:16:00
  • python报错TypeError: ‘NoneType‘ object is not subscriptable的解决方法

    2023-01-11 08:11:07
  • Python3环境安装Scrapy爬虫框架过程及常见错误

    2021-10-19 00:01:05
  • Visual Studio 2017使用EF选择MySQL数据源

    2024-01-25 04:13:23
  • python3在各种服务器环境中安装配置过程

    2021-10-27 22:49:55
  • node基于express框架操作Mysql数据库的步骤

    2024-01-22 11:09:54
  • Python flask与fastapi性能测试方法介绍

    2022-12-07 00:10:17
  • django基于restframework的CBV封装详解

    2021-09-25 20:25:25
  • 通过PHP current函数获取未知字符键名数组第一个元素的值

    2023-11-15 04:52:07
  • 分享几种python 变量合并方法

    2023-09-27 12:59:02
  • Keras loss函数剖析

    2021-01-24 05:25:27
  • 驯服不听话的网页表格

    2007-12-03 11:36:00
  • Selenium 滚动页面至元素可见的方法

    2022-06-01 14:01:05
  • asp之家 网络编程 m.aspxhome.com