tinymce 如何实现动态国际化
tinymce 如何实现动态国际化
tinymce 是一个非常强大的富文本编辑器,tinymce 是支持开启通过配置 language
来决定 tinymce 的语言版本例如下面配置 日文 英文 中文 且在同一个页面
注意 需要每一个 tinymce editor 实例 完成之后才能进行实例下一个 所有需要采用 tinymce.init({...}).then(()=>{ tinymce.init({...}).then(()=>{ ... })... })
的用法。 否则只能得到 最后一个实例的语言版本
但是问题来了 因为 tinymce 的菜单面板 是动态生成 , tinymce 官方 这一块的逻辑并没有考虑到 不同语言实例在 同一页面,【具体,可以近似看成 原型链的问题 】,所以菜单面板的语言就会出现 生成的是最后一个语言配置, 如下图 英文实例 菜单 生成 结果为中文
那么这个问题该 如何解决
解决方案就是 当鼠标 在每个 tinymce 实列上方,立即进行一次语言重置。
具体方案 ,通过 如下代码
解决方案 我已经集成 到了 Tinymce-plugin 中
你可以通过下载 tinymce-plugin, 并配置 tp_i18n 为 true 来实现 优雅的同时渲染多语言版本,实现代码如下:
同时 tinymce-plugin 也集成实现了 tinymce 动态国际化
通过配置 tp_i18n_langs: true
然后自定义菜单项 加入 tpI18n
来开启此项功能
实现如下
动态修改前为英文
动态修改后为韩文
版权声明: 本文为 InfoQ 作者【Five】的原创文章。
原文链接:【http://xie.infoq.cn/article/ecb929d16901b9455291cbcae】。
本文遵守【CC-BY 4.0】协议,转载请保留原文出处及本版权声明。
评论