Tinymce group plugin

本文介绍一个tinymce插件,用来组合显示下拉的按钮。基于4.x,不兼容3.x。

以前

配置toolbar功能按钮

需要

toolbar1: "code undo redo fullscreen"
    plugins: "code, fullscreen"

页面就能显示

配置 toolbar下拉的功能按钮集合,需要新写一个插件

插件核心源码:

editor.addButton(‘undoRedo‘, {
      type: ‘menubutton‘,
      icon: ‘mceIcon mce-i-undo‘,
       menu: [
          {
              text: ed.getLang(‘Undo‘),
              icon: ‘mceIcon mce-i-bold‘,
              onclick: function() {
                  ed.execCommand(‘Undo‘);
              }
          },
          {
              text: ed.getLang(‘Redo‘),
              icon: ‘mceIcon mce-i-redo‘,
              onclick: function() {
                  ed.execCommand(‘Redo‘);
              }
          }
      ]
});

就能看到

现在

现在我们想要实现这类下拉功能菜单:

当然作为备选方案,可以使用使用上面提到的add menuButton的方式。不过这样的缺点是,我们如果需要5个下拉功能菜单,就不得不写五个插件,而都是重复的工作。

当一件事开始重复的时候,就一定有方法可以让其变的简单。

我们的解决办法是,通过一个插件,来配置多个下拉功能菜单。

talk is chip, show you the code:

使用配置:

toolbar1: ‘undo redo | group group group group group | fullscreen‘,
  group_set: [{
      icon: ‘alignleft‘,
      buttons: ‘alignleft,aligncenter,alignright‘,
      title: ‘Align center‘
  }, {
      icon: ‘bullist‘,
      buttons: ‘bullist,numlist‘,
      title: ‘advanced.bullist_desc‘
  }, {
      icon: ‘indent‘,
      buttons: ‘indent,outdent‘,
      title: ‘advanced.indent_desc‘
  }, {
      icon: ‘subscript‘,
      buttons: ‘superscript,subscript‘,
      title: ‘advanced.sup_desc‘
  },{
      icon: ‘image‘,
      buttons: ‘alitophotobank,image, aliphotobank‘,
      title: ‘advanced.sup_desc‘
}];

效果:

plugin group实现

修改 toolbar 配置

toolbar1配置了5个group占位符,但是addButton的第一个参数name一定要和toolbar上的占位配置一致,所以第一步是修改 settings.toolbar上的group占位符。

// 修改 setting中toolbar上的group,group为group1,group2
    modifySettingToolbar: function(ed) {
        var index = 1;
        var settings = ed.settings;
        if(!settings.toolbar1 && !settings.toolbar2 && !settings.toolbar3) return false;

var toolbar1 = settings.toolbar1.split(‘ ‘),
            toolbar2 = settings.toolbar2.split(‘ ‘),
            toolbar3 = settings.toolbar3.split(‘ ‘);

[toolbar1, toolbar2, toolbar3].forEach(function(item) {
            for (var i = 0; i < item.length; i++) {
                if(item[i] == ‘group‘) {
                    item[i] = ‘group‘ + index;
                    index ++;
                }
            };
        });
        this.toolbarNum = index;
        settings.toolbar1 = toolbar1.join(‘ ‘);
        settings.toolbar2 = toolbar2.join(‘ ‘);
        settings.toolbar3 = toolbar3.join(‘ ‘);
 },

插件核心代码

//编辑器初始化后将初始化一个插件实例
    init: function(ed, url) {
        //在这个实例中我们保存一些编辑器的公用信息
        this.ed = ed;
        //保留配置信息
        this.settings = ed.settings;
        // 注意 4.x 没有3.x的 ed.onInit 方法
        ed.on(‘init‘, function() {
            this.createControl(ed);
        }.bind(this));
    },
    // 创建 group button
    createControl: function(ed) {
        var _set = this.settings;

this.modifySettingToolbar(ed);
        for (var i = 1; i < this.toolbarNum; i++) {

var _item = _set.group_set[i-1]; //获取多组信息
            if(!_item) return false;
            var _buttons = _item ? _item.buttons.split(‘,‘) : [],
                subItem = [];

for (var j = 0, l = _buttons.length; j < l; j++) {

btn  = _buttons[j] && _buttons[j].trim();

subItem.push({
                    //配置标题信息则需要考虑到语言和主题
                    text: ed.getLang(BUTTONS_MAP[btn] && BUTTONS_MAP[btn][0]),
                    //图标类自己创建的话则需要注意格式
                    icon: ‘mceIcon mce-i-‘ + btn,
                    //执行的命令 闭包传入当前btn
                    onclick: (function(btn) {
                       var cmd = BUTTONS_MAP[btn] && BUTTONS_MAP[btn][1];
                       return function(e) {
                          ed.execCommand(cmd);
                       }
                   })(btn)
                });
            }
            ed.addButton(‘group‘ + i, {
                type: ‘menubutton‘,
                icon: _item.icon || ‘‘,
                menu: subItem
            });
        }
        return false;
 },

注释已经很详细了,就不讲解代码了。

其中的BUTTONS_MAP是我配置的一个title&cmd的map:

// 目前 plugin group支持的一些功能map

var BUTTONS_MAP = {
  bold : [‘Bold‘, ‘Bold‘],
  italic : [‘Italic‘, ‘Italic‘],
  underline : [‘Underline‘, ‘Underline‘],
  strikethrough : [‘Strikethrough‘, ‘Strikethrough‘],
  alignleft : [‘Align left‘, ‘JustifyLeft‘],
  aligncenter : [‘Align center‘, ‘JustifyCenter‘],
  alignright : [‘Align right‘, ‘JustifyRight‘],
  alignjustify : [‘Alignment‘, ‘JustifyFull‘],
  bullist : [‘Bullet list‘, ‘InsertUnorderedList‘],
  numlist : [‘Numbered list‘, ‘InsertOrderedList‘],
  outdent : [‘Decrease indent‘, ‘Outdent‘],
  indent : [‘Increase indent‘, ‘Indent‘],
  cut : [‘Cut‘, ‘Cut‘],
  copy : [‘Copy‘, ‘Copy‘],
  paste : [‘Paste‘, ‘Paste‘],
  undo : [‘Undo‘, ‘Undo‘],
  redo : [‘Redo‘, ‘Redo‘],
  link : [‘Insert link‘, ‘mceLink‘],
  unlink : [‘Remove link‘, ‘unlink‘],
  image : [‘Insert image‘, ‘mceImage‘],
  removeformat : [‘Clear formatting‘, ‘mceCleanup‘],
  help : [‘help‘, ‘mceHelp‘],
  code : [‘Source code‘, ‘mceCodeEditor‘],
  hr : [‘Horizontal line‘, ‘InsertHorizontalRule‘],
  superscript : [‘Subscript‘, ‘subscript‘],
  subscript : [‘Superscript‘, ‘superscript‘],
  newdocument : [‘New document‘, ‘mceNewDocument‘],
  blockquote : [‘Blockquote‘, ‘mceBlockQuote‘]
};

以上就是group的使用方式和源码解释,希望能帮到你。

源码托管在github:  点我下载

时间: 2024-10-17 04:24:29

Tinymce group plugin的相关文章

Django Tinymce 加入 syntaxhl(语法高亮插件)

首先看这篇文章安装Tinymce:http://blog.csdn.net/dreamzml/article/details/8842409 接下来似乎网上有一两种方法 ,我只说我成功的一种 1 下载syntaxhighlighter 3.0.83,解压复制到Django的静态目录(我的是static/) 2 下载syntaxhl,复制到tinymce的plugin目录下(我在静态目录下和tinymce app的目录下都放了,肯定是多放了一个) 3 以下字段加进主settings.py 1 #T

可视化HTML编辑器

[荐] 可视化HTML编辑器 CKEditor CKEditor是新一代的FCKeditor,是一个重新开发的版本.CKEditor是全球最优秀的网页在线文字编辑器之一,因其惊人的性能与可扩展性而广泛的被运用于各大网站. 可配合使用的扩展有 文件管理器KCFinder 在线演示:h...更多CKEditor信息 最新新闻: CKEditor 4.5.6 发布,可视化 HTML 编辑器 2015年12月10日 [荐] 可视化HTML编辑器 KindEditor KindEditor 是一套开源的在

插件化编程实现的一份糖炒栗子~~

迷茫的原因是因为想得太多,做得太少.因为只是 想 真的很容易,转瞬之间就会产生无数个念头,或许是该做点什么了吧. 但是整个人都是懒的,是废的,是大脑控制不住自己的行为的.解决方案唯有一步一步的去把行为变成习惯. 坚持一件事挺不容易的,不论结果的好坏,过程中总有收获的,坚持,不会是一件坏事. 胡言乱语结束~~~ 下面是记录分享的一点东西~~请笑纳 0.结构一览 1.定义插件接口 using System; using System.Collections.Generic; using System

张左峰的歪理邪说 之 大话Redmine插件

Redmine是一个比较轻量级的综合项目管理工具,包括了很多项目管理中需要的工具,并且有效的把他们做了一个集合的工作平台,并且支持插件扩展模式,其中官网上提供的插件极为丰富,而且有些对工作帮助挺大,介绍并推荐一些插件. 我所使用的Redmine版本为0.9.6 Redmine开发团队实在太激进了,真是太敬业了,这种应用系统不求新,求稳定.所以一直也没更新到最新版,现在好像都1.1.X了.所以插件也是基于0.9.6版来做介绍. 1.  ezFAQ plugin a)   一个很有趣的结合问题条目的

开发XMPP IM

Openfire 是一个用Java 实现的XMPP 服务器,客户端可以通过IQ的方式与其进行通信(其实就是XML),客户端和服务器之间的通信是依靠底层Smack 库提供的各种功能来完成的.其实利用插件方式来扩展Openfire 服务器端主要有两种扩展方式,一种是对服务器控制台页面进行扩展(不是本文的主要内容),即遵循Openfire 页面的布局方式,进行相应的页面扩展和功能扩展:另一种是对通信功能进行扩展.本文主要针对后者进行具体的描述. 本篇文章的结构如下: 1.创建plugin.xml(这是

db2配置、db和dbm

----start DB2 可以在四个不同层面配置: 一:系统环境变量(System Environment Variable) 系统环境变量用来配置DB2 的使用环境: [c-sharp] view plain copy print? 查看:set | grep DB2 DB2DIR=/opt/ibm/db2/V9.5 --DB2安装目录 DB2INSTANCE=db2inst1 --当前活动的实例 二:DB2 概要文件注册表(Profile Registry) 有两种DB2 概要文件注册表变

Linux -- sudoers文件

ASUDOERS(5)                                                    BSD File Formats Manual                                                    SUDOERS(5) NAME     sudoers — default sudo security policy plugin DESCRIPTION     The sudoers policy plugin dete

OpenStack Networking overview

原文地址:http://docs.openstack.org/newton/install-guide-ubuntu/neutron-concepts.html Networking service overview OpenStack Networking(neutron)能够让我们创建由其他OpenStack service管理的网络设备,并且将它们加入networking.Plug-in的实现方式能让我们容纳不同类型的网络设备和软件,并且为OpenStack的架构和部署提供了灵活性.它由以

板邓:wordpress去掉头部多余的js / css/ feed

wordpress去掉头部多余的js 复制代码添加到function.php文件 /** * Disable the emoji's去掉头部自动加载的js */ function disable_emojis() { remove_action( 'wp_head', 'print_emoji_detection_script', 7 ); remove_action( 'admin_print_scripts', 'print_emoji_detection_script' ); remove