当前位置:网站首页>tinymce-plugins

tinymce-plugins

2022-08-02 13:07:00 InfoQ

tinymce-plugins

This is tinymce plugins

前言

因为项目需要用到富文本编辑器众多富文本编辑器中,选择了 Tinymce,根据项目需要对Tinymce 进行扩展和增强插件,记录一下,并同时分享给需要帮助的人。
目前正在全力调整重构 

tinymce 官方文档
tinymce 中文文档
插件下载地址
项目demo地址
CSDN 博客
个人博客
QQ邮箱: [email protected]

简述

This is tinymce plugins该项目主要为 tinymce 富文本编译器的扩展插件,或增强优化插件目前整理完成插件列表如下:
  •  imagetools [增强优化]: 图片编辑工具插件, 对图片进行处理。优化跨域,功能更丰富;
  •  table [增强优化]:表格插件,处理表格。 增强优化表格控制,增加表格转图片功能,便捷布局按钮;
  •  indent2em[增强优化]:首行缩进插件。提供中文段落排版的首行缩进2个字符的功能。增强优化 加入字间距非默认情况,也能实现准确首行缩进2字符;
  •  letterspacing:设置间距插件。可以设置文档中的文字间距;
  •  layout: 一键布局插件。可以给文档段落进行一键快速排版布局;
  •  importword: 导入word插件。可以直接导入word ,并且保证word中图片不会丢失,自动转为base64;
  •  upfile: 文件上传。可以点击导入文件,可自定义编辑文件名;
  •  bdmap: 百度地图。 支持更改尺寸,自定义标签,开启导航功能,支持vue;
  •  axupimgs: 多图上传。可同时上传多组图片,支持vue;
  •  attachment: 附件上传。拥有附件类型对应图标,支持vue;

下载

 npm i @npkg/tinymce-plugins 或 cnpm i @npkg/tinymce-plugins -D

使用说明

未使用过 tinymce ,可以查看莫若卿大佬的 
tinymce 中文文档
imagetools 使用方法:
增强效果:[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-f1R6Xv8K-1621387811879)(https://s3.ax1x.com/2020/12/28/ro4Lng.png)]
 tinymce.init({
 selector: '#tinydemo',
 plugins: "image imagetools",
 toolbar: "image",
 });
点击下载
 
更多下载
更多配置 见 
插件 / imagetools
table 使用方法:
增强效果:
null
提供一个配置项目 table_icons 自定义图标配置【Object】可配置icon 对象为
  • align-left-table: 表格居左
  • align-center-table: 表格居中
  • align-right-table: 表格居右
  • table-to-img: 表格转图片
tinymce.init({
 selector: '#tinydemo',
 plugins: "table",
 toolbar: "table"
 table_icons: {// 以下下为默认配置
 'align-right-table': '<svg width=&quot;24&quot; height=&quot;24&quot;><path d=&quot;M5 5h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 1 1 0-2zm6 4h8c.6 0 1 .4 1 1s-.4 1-1 1h-8a1 1 0 0 1 0-2zm0 8h8c.6 0 1 .4 1 1s-.4 1-1 1h-8a1 1 0 0 1 0-2zm-6-4h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 0 1 0-2z&quot; fill-rule=&quot;evenodd&quot;></path></svg>',
 'align-left-table': '<svg width=&quot;24&quot; height=&quot;24&quot;><path d=&quot;M5 5h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 1 1 0-2zm0 4h8c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 1 1 0-2zm0 8h8c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 0 1 0-2zm0-4h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 0 1 0-2z&quot; fill-rule=&quot;evenodd&quot;></path></svg>',
 'align-center-table': '<svg width=&quot;24&quot; height=&quot;24&quot;><path d=&quot;M5 5h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 1 1 0-2zm3 4h8c.6 0 1 .4 1 1s-.4 1-1 1H8a1 1 0 1 1 0-2zm0 8h8c.6 0 1 .4 1 1s-.4 1-1 1H8a1 1 0 0 1 0-2zm-3-4h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 0 1 0-2z&quot; fill-rule=&quot;evenodd&quot;></path></svg>'
 }
});
点击下载
&nbsp;
更多下载
更多配置 见&nbsp;
插件 / table
indent2em 使用方法:
当使用 本项目 letterspacing 插件,如需使用首行缩进 请替换原有indent2em,使用该项目indent2em插件。
tinymce.init({
 selector: '#tinydemo',
 plugins: &quot;indent2em&quot;,
 toolbar: &quot;indent2em&quot;
});
点击下载
&nbsp;
更多下载
更多配置 见&nbsp;
插件 / indent2em
letterspacing 使用方法:
tinymce.init({
 selector: '#tinydemo',
 plugins: &quot;letterspacing&quot;,
 toolbar: &quot;letterspacing&quot;
});
点击下载
&nbsp;
更多下载
更多配置(选配) :
提供字段 letterspacing 配置参数【String类型】,空格隔开;
tinymce.init({
 selector: '#tinydemo',
 plugins: &quot;letterspacing&quot;,
 toolbar: &quot;letterspacing&quot;,
 letterspacing: &quot;0px 2px 4px 6px 24px&quot;
});
layout 使用方法:
tinymce.init({
 selector: '#tinydemo',
 plugins: &quot;layout&quot;,
 toolbar: &quot;layout&quot;
});
点击下载
&nbsp;
更多下载
更多配置 (选配):
提供 一键布局 默认参数字段 layout_options 配置参数【Object类型】目前一共4个属性:
  • style : 一键布局默认样式参数【Object】
  • filterTags: 【Array】过滤标签,该数组中的标签,一键布局中将会被忽略(默认忽略 ‘table’,‘tbody’,‘td’,‘tr’)
  • tagsStyle: 单独标签样式处理【Object】
  • clearStyle: 【Array】清除样式 ,一键布局后 ,数组中的样式将会清除掉。
配置优先级从低到高: style < filterTags < tagsStyle < clearStyle
tinymce.init({
 selector: '#tinydemo',
 plugins: &quot;layout&quot;,
 toolbar: &quot;layout&quot;,
 layout_options: {
 style: {
 'text-align':'justify',
 'text-indent':'2em',
 'line-height': 1.5
 },
 filterTags:['table>*','tbody'], //'table,'tbody','td','tr' 将会忽略掉 同时 table>*,忽略table 标签 以及所有子标签
 clearStyle: ['text-indent'],//text-indent 将会被清除掉
 tagsStyle: {
 'table': {
 'line-height': 3,
 'text-align': 'center'
 },
 'table,tbody,tr,td': { //支持并集选择
 'line-height': 2
 },
 'tr>td,table>tbody': { //支持, 精准定位 通过 ' > '
 'line-height': 3,
 'text-align': 'center'
 }
 }
 }
});
importword 使用方法:
tinymce.init({
 selector: '#tinydemo',
 plugins: &quot;importword&quot;,
 toolbar: &quot;importword&quot;
});
点击下载
&nbsp;
更多下载
更多配置(选配) :
提供 导入word 插件预处理函数 importword_handler 配置参数【Function类型】传入3个参数
  • editor : editor 编辑器实列【object】
  • files : 导入的文件 【object】
  • next : 下一步骤回调函数 传入files标签字符串【Function】
过滤函数 importword_filter 配置参数【Function类型】传入3个参数
  • result : 导入word 生成的 html标签字符串【String】
  • insert : 插入回调函数 传入 html标签字符串【String】
  • message: 转换过程中产生的错误信息集【Array】
tinymce.init({
 selector: '#tinydemo',
 plugins: &quot;importword&quot;,
 toolbar: &quot;importword&quot;,
 importword_handler: function(editor,files,next){
 var file_name = files[0].name
 if(file_name.substr(file_name.lastIndexOf(&quot;.&quot;)+1)=='docx'){
 editor.notificationManager.open({
 text: '正在转换中...',
 type: 'info',
 closeButton: false,
 });
 next(files);
 }else{
 editor.notificationManager.open({
 text: '目前仅支持docx文件格式,若为doc111,请将扩展名改为docx',
 type: 'warning',
 });
 }
 // next(files);
 }
 importword_filter: function(result,insert,message){ 
 // 自定义操作部分
 insert(result) //回插函数
 }
});
upfile 使用方法:
tinymce.init({
 selector: '#tinydemo',
 plugins: &quot;upfile&quot;,
 toolbar: &quot;upfile&quot;
});
点击下载
&nbsp;
更多下载
更多配置(选配) :
提供 upfile 插件 过滤函数 file_callback 配置参数【Function类型】传入2个参数
  • file : 文件对象【file】
  • succFun : 成功回调函数 传入 html标签字符串【Function类型】(url|string,obj)
tinymce.init({
 selector: '#tinydemo',
 plugins: &quot;upfile&quot;,
 toolbar: &quot;upfile&quot;,
 file_callback: function (file, succFun) {
 // 自定义处理文件操作部分
 succFun(url,{text: 'xx.pdf'}) //成功回调函数 text 显示的文本
 }
});
bdmap 使用方法:
tinymce.init({
 selector: '#tinydemo',
 plugins: &quot;bdmap&quot;,
 toolbar: &quot;bdmap&quot;
});
点击下载
&nbsp;
更多下载
更多配置(选配) :
提供&nbsp;
bdmap
&nbsp;插件&nbsp;
bdmap_options
&nbsp;配置参数【object】 传入 4 个参数
  • width: 百度地图默认宽度 默认 560
  • height: 百度地图默认高度 默认 360
  • outputIframe: 百度地图输出iframe路径, 默认 ‘.’ (当前路径)&nbsp;
    Vue
    &nbsp;默认 ‘https://unpkg.com/@npkg/tinymce-plugins/plugins/bdmap/bd.html’
  • apiKey: 自定义百度地图apiKey&nbsp;
    Vue
    &nbsp;中有效
tinymce.init({
 selector: '#tinydemo',
 plugins: &quot;bdmap&quot;,
 toolbar: &quot;bdmap&quot;,
 bdmap_options: {
 width: 560,
 height: 360,
 outputIframe: 'https://unpkg.com/@npkg/tinymce-plugins',
 apiKey: 'ONXXXXXXXXXXXXXXnP'
 }
});
axupimgs(Vue)使用方法:
tinymce.init({
 selector: '#tinydemo',
 plugins: &quot;axupimgs&quot;,
 toolbar: &quot;axupimgs&quot;
});
点击下载
&nbsp;
更多下载
更多配置 见&nbsp;
插件 / axupimgs
attachment 使用方法:
tinymce.init({
 selector: '#tinydemo',
 plugins: &quot;attachment&quot;,
 toolbar: &quot;attachment&quot;
});
点击下载
&nbsp;
更多下载
更多配置(选配) :
提供&nbsp;
attachment
&nbsp;插件 提供&nbsp;
attachment_max_size
attachment_style
,
attachment_icons_path
,
attachment_upload_handler
&nbsp;配置参数attachment_max_size: 附件大小限制 默认 209715200 (200M)【number】attachment_style: 附件的样式,主要为保存数据后可以直接在其他页面展示。 【string】attachment_icons_path: 附件的 图标的路径 icons , 默认 当前路径&nbsp;
Vue
&nbsp;默认 ‘https://unpkg.com/@npkg/tinymce-plugins/plugins/attachment/icons’attachment_upload_handler: 附件上传处理函数 【function】 function(file, succFun, failFun, progressCallback)
  • file : 文件对象【file】
  • succFun : 成功回调函数 传入 (url|string)
  • failFun : 失败回调函数 传入 (string)
  • progressCallback: 进程回调函数 传入 (string)

var xhrOnProgress = function (fun) {
 xhrOnProgress.onprogress = fun;
 return function () {
 var xhr = $.ajaxSettings.xhr();
 if (typeof xhrOnProgress.onprogress !== 'function')
 return xhr;
 if (xhrOnProgress.onprogress && xhr.upload) {
 xhr.upload.onprogress = xhrOnProgress.onprogress;
 }
 return xhr;
 }
 }

tinymce.init({
 selector: '#tinydemo',
 plugins: &quot;attachment&quot;,
 toolbar: &quot;attachment&quot;,
 attachment_max_size: 209715200,
 attachment_style:'.attachment>img{display:inline-block!important;max-width:30px!important;}'
 attachment_icons_path: 'https://unpkg.com/@npkg/tinymce-plugins/plugins/attachment/icons',
 attachment_upload_handler: function (file, succFun, failFun, progressCallback) {
 var data = new FormData();
 data.append(&quot;file&quot;, file);
 $.ajax({
 data: data,
 type: 'GET',
 url: './api/file.json',
 cache: false,
 contentType: false,
 processData: false,
 header:{'Content-Type':'multipart/form-data'},
 dataType: 'json',
 xhr: xhrOnProgress(function (e) {
 const percent = (e.loaded / e.total * 100 | 0) + '%';//计算百分比
 progressCallback(percent);
 }),
 }).then(function (data) {
 if ( data.code== 200) {
 succFun(data.data);
 } else {
 failFun('上传失败:' + data.data);
 }
 }).fail(function (error) {
 failFun('上传失败:' + error.message)
 });
 },

 
});

在vue当中使用

只需将插件下载后引用到安装目录中

|-- node_modules
| ...
| |-- tinymce
| | .
| |-- |-- plugins
| | | |-- letterspacing
| | | |-- layout
| | | |-- indent2em
| | | |-- importword
| | | |-- imagetools
| | | |-- table
| | | |-- bdmap
| | | |-- axupimgs
| | | |-- attachment
| ...

引入
可以全部引入
 import '@npkg/tinymce-plugins'
也可以按需引入
import '@npkg/tinymce-plugins/importword' 
import '@npkg/tinymce-plugins/lineheight' 
import '@npkg/tinymce-plugins/layout' 
import '@npkg/tinymce-plugins/letterspacing' 
import '@npkg/tinymce-plugins/indent2em' 
import '@npkg/tinymce-plugins/upfile' 
import '@npkg/tinymce-plugins/imagetools'
import '@npkg/tinymce-plugins/attachment'

欢迎提出建议,动手点赞 ,或提pr

目前项目正在重构调整

 力求创建一个 提供&nbsp;
强大、好用、丰富
&nbsp;的&nbsp;
tinymce
&nbsp;富文本编辑器&nbsp;
插件
扩展
&nbsp;和&nbsp;
技术
&nbsp;的技术社区,方便&nbsp;
交流讨论
分享经验
&nbsp;。 本社区有多个不错的插件或者项目,欢迎 Star&nbsp;&nbsp;关注~
新项目文档网站(测试):
https://tinymce-plugin.github.io/

原网站

版权声明
本文为[InfoQ]所创,转载请带上原文链接,感谢
https://xie.infoq.cn/article/4a8c06acaa854d50bf0f72cf0