TinyEditor:简洁且易用的html所见即所得编辑器

转自:http://www.cnwebshow.com/edu/article_64623.html

 

TinyEditor有以下特点

它使用Javascript编写,不依赖于其它类库 这是一个轻量级的编辑器,要调用的文件仅有8kb 它可以处理大多数的html格式化需求,并且内置的功能使得生成的标记尽量简洁 编辑器中用到的小图标使用了CSS Sprite技术,减少了http连接 在主流浏览器中测试通过

可个人或商业项目中使用,遵循creative commons license。

下面来看如何使用:

 

1. 在网页文件中引用TinyEditor提供的js文件和css文件;
2. 在网页文件中添加编辑器所需要的标签,其实就是个textarea,如下

<textarea id="input" style="width:400px; height:200px"></textarea>

注意:textarea中定义的长宽也就是编辑器的大小。
3. 通过脚本初始化编辑器,并配置各种参数,如下:

new TINY.editor.edit('editor',{
    id:'input',
// (必须)上面第二步中定义的textarea的id
    width:584,
// (选填) 编辑器宽度
    height:175,
 // (选填) 编辑器高度
    cssclass:'te',
 // (选填) 编辑器的class,用来通过css控制样式
    controlclass:'tecontrol',
 // (选填) 编辑器上按钮的class
    rowclass:'teheader',
 // (选填) 编辑器按钮行的class
    dividerclass:'tedivider',
// (选填) 编辑器按钮间分割线的样式
    controls:['bold', 'italic', 'underline', 'strikethrough', '|', 'subscript', 'superscript', '|', 
'orderedlist', 'unorderedlist', '|' ,'outdent' ,'indent', '|', 'leftalign', 'centeralign', 'rightalign',
'blockjustify', '|', 'unformat', '|', 'undo', 'redo', 'n', 'font', 'size', 'style', '|', 'image', 'hr',
'link', 'unlink', '|', 'cut', 'copy', 'paste', 'print'], // (必须) 要根据需要在编辑器上添加按钮控件, 其中'|'代表功能按钮间的竖分割线,'n'代表按钮行间的分割线 footer:true, // (选填) 是否显示编辑器底部 fonts:['Verdana','Arial','Georgia','Trebuchet MS'], // (选填) 编辑器中可选择的字体 xhtml:true, // (选填) 编辑器生成xhtml还是html标记 cssfile:'style.css', // (选填) 要为编辑器附加的外部css文件 content:'starting content', // (选填) 设置编辑器编辑区域中的初始内容 css:'body{background-color:#ccc}', // (选填) 设置编辑器编辑区域背景 bodyid:'editor', // (选填) 设置编辑区域ID footerclass:'tefooter', // (选填) 设置编辑器底部class toggle:{text:'源代码',activetext:'可视化',cssclass:'toggle'}, // (选填) 设置源代码浏览切换文字,及切换按钮的class resize:{cssclass:'resize'} // (选填) 设置编辑器大小调整按钮的class });

注意:可以说的上是高度可配置了,而且配置项都比较清晰。

在TinyEditor的实际应用中,需要注意的是,在提交编辑器内容之前,一定调用instance.post()函数,以确保编辑区域中最新的可视化内容转化为标记文本。

查看示例:http://sandbox.leigeber.com/tinyeditor/

 

网上只能找到tinyeditor的英文版本,对于国内用户还是不太方便,自己动手汉化了一下,并且将编码改成了gbk,希望可以帮助有需要的朋友。 下面是关于tinyeditor的介绍(摘自网络): 前几日曾给大家介绍过一款国产的xhtml编辑器,今天要给大家推荐的TinyEditor,是国外知名Web设计博客leigeber.com刚发布的一款简洁易用html所见即所得编辑器TinyEditor有以下特点 •它使用Javascript编写,不依赖于其它类库 •这是一个轻量级的编辑器,要调用的文件仅有8kb •它可以处理大多数的html格式化需求,并且内置的功能使得生成的标记尽量简洁编辑器中用到的小图标使用了CSS Sprite技术,减少了http连接 •在主流浏览器中测试通过 •可个人或商业项目中使用,遵循creative commons license 下面来看如何使用: 1,在网页文件中引用TinyEditor提供的js文件和css文件 2,在网页文件中添加编辑器所需要的标签,其实就是个textarea,如下 <textarea id="input" height:200px"></textarea> 注意textarea中定义的长宽也就是编辑器的大小。 3,通过脚本初始化编辑器,并配置各种参数,如下: new TINY.editor.edit('editor',{ id:'input', // (必须)上面第二步中定义的textarea的id width:584, // (选填) 编辑器宽度 height:175, // (选填) 编辑器高度 cssclass:'te', // (选填) 编辑器的class,用来通过css控制样式 controlclass:'tecontrol', // (选填) 编辑器上按钮的class rowclass:'teheader', // (选填) 编辑器按钮行的class dividerclass:'tedivider', // (选填) 编辑器按钮间分割线的样式 controls:['bold', 'italic', 'underline', 'strikethrough', '|', 'subscript', 'superscript', '|', 'orderedlist', 'unorderedlist', '|' ,'outdent' ,'indent', '|', 'leftalign', 'centeralign', 'rightalign', 'blockjustify', '|', 'unformat', '|', 'undo', 'redo', 'n', 'font', 'size', 'style', '|', 'image', 'hr', 'link', 'unlink', '|', 'cut', 'copy', 'paste', 'print'], // (必须) 要根据需要在编辑器上添加按钮控件, 其中'|'代表功能按钮间的竖分割线,'n'代表按钮行间的分割线 footer:true, // (选填) 是否显示编辑器底部 fonts:['Verdana','Arial','Georgia','Trebuchet MS'], // (选填) 编辑器中可选择的字体 xhtml:true, // (选填) 编辑器生成xhtml还是html标记 cssfile:'style.css', // (选填) 要为编辑器附加的外部css文件 content:'starting content', // (选填) 设置编辑器编辑区域中的初始内容 css:'body{background-color:#ccc}', // (选填) 设置编辑器编辑区域背景 bodyid:'editor', // (选填) 设置编辑区域ID footerclass:'tefooter', // (选填) 设置编辑器底部class toggle:{text:'源代码',activetext:'可视化',cssclass:'toggle'}, // (选填) 设置源代码浏览切换文字,及切换按钮的class resize:{cssclass:'resize'} // (选填) 设置编辑器大小调整按钮的class }); 可以说的上是高度可配置了,而且配置项都比较清晰。 在TinyEditor的实际应用中,需要注意的是,在提交编辑器内容之前,一定调用instance.post()函数,以确保编辑区域中最新的可视化内容转化为标记文本。 查看示例:http://sandbox.leigeber.com/tinyeditor/
在Vue3中使用TinyMCE富文本编辑器导入Word文件,通常需要通过插件来实现,因为TinyMCE本身并不直接支持Word文档导入。一个常用的插件是`file-image-upload-plugin`,这个插件允许用户上传各种类型的文件,包括Word文档。 以下是大致步骤: 1. 安装插件: 首先,在项目中安装TinyMCE的file-image-upload-plugin: ``` npm install @tinymce/file-image-upload ``` 2. 配置插件: 在`main.js`或你的组件里,初始化TinyMCE并配置插件: ```javascript import { TinyEditor } from '@tinymce/tinymce-vue' import FileImageUpload from '@tinymce/file-image-upload' Vue.use(TinyEditor) Vue.use(FileImageUpload) // 初始化TinyMCE tinymce.init({ plugins: 'file_image_upload', selector: 'textarea', // 替换为你实际的富文本输入元素 image_dimensions_sample: true, file_picker_callback: function (callback) { callback( /* { type: 'custom', async: true, upload: function (blobInfo, success, failure) { const formData = new FormData(); formData.append('file', blobInfo.blob(), blobInfo.name()); await axios.post('/api/upload-word', formData) .then(response => { if (response.status === 200) { success({ url: response.data.url }); } else { failure(); } }) .catch(failure); }, }*/ ); }, }); ``` 这里的`file_picker_callback`是一个自定义函数,用于处理文件上传。你需要替换`axios.post`部分为实际的文件上传服务,并根据返回数据更新`success`回调中的URL。 3. 文件上传逻辑: 这部分依赖于你的服务器端API,你需要创建一个接收Word文件、转换并保存到数据库或服务器存储的地方,然后返回新的URL给前端。 **注意**:这只是一个基础示例,实际应用中可能需要处理更多边界情况,例如错误处理、文件类型验证等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值