我正在将TinyMCE 3.x插件迁移到4.x
该插件使用由各个HTML文件定义的许多对话框。这些文件内部有国际化的字符串,例如,
<select id="reading" name="reading">
<option value="corr">{#wce.correction}</option>
<option value="comm">{#wce.commentary}</option>
<option value="alt">{#wce.alternative}</option>
</select>
在TinyMCE 3.x中,似乎popup插件通过tinymce的翻译工具运行此内容,但使用4.x,调用:
tinymce.activeEditor.windowManager.open
字符串无法翻译。
有什么建议吗?
答案 0 :(得分:1)
好的,所以看看3.x tinymce_popup代码,我已经抓住了相应的行,我现在正在我的对话框html文件中执行此操作:
$(document).ready(function() {
translate();
});
function translate() {
var c=document.body.innerHTML;
var d=document.title;
var a;
if(top.tinymce.isIE){c=c.replace(/ (value|title|alt)=([^"][^\s>]+)/gi,' $1="$2"')}
a=c.replace(/\{\#([^\}]+)\}/g, function(a, b) {
var c=top.tinymce.translate(b);
return (c != b) ? c : '{#' + b + '}';
});
if(a!=c){document.body.innerHTML=a}
a=d.replace(/\{\#([^\}]+)\}/g, function(a, b) {
var c=top.tinymce.translate(b);
return (c != b) ? c : '{#' + b + '}';
});
if(a!=d){document.title=d=a}
}
我还必须编辑我的插件区域设置文件,以从字符串的注册中删除插件名称。例如,来自:
tinyMCE.addI18n('en.wce',{
'key' : 'value',
...
到
tinymce.addI18n('en',{
'key' : 'value',
...
和我所有的
{#wce.tokens}
简单地
{#tokens}
在我的HTML中。
这让我现在大部分都在工作。希望它对其他人有所帮助。