我想表示一个具有多个文本属性的对象,每个属性代表相同的文本值但使用不同的语言。如果用户修改单个字段,其他字段应该修改,我正在考虑在其他字段的字符串的开头添加一个Unicode字符,然后检查需要注意的字段,我只是必须检查obj.text_prop[0]
处的值。
我可以将哪个Unicode字符用于此目的?理想情况下,它是不可打印的,在JS和JSON中支持。
答案 0 :(得分:1)
这种标记应该在字符级别以外的协议级别以其他方式完成。例如,考虑使每个语言版本成为一个对象而不仅仅是一个字符串;除了包含字符串的属性外,该对象还可以具有needsAttention
等属性。
但是如果您需要将这些信息嵌入到字符串中,那么您可以使用ZERO WIDTH SPACE U + 200B。因此,它意味着断线机会,但这不应该打扰这里。主要问题可能是IE的旧版本可能会将其显示为一个小矩形。
或者,您可以使用非字符代码点(如U + FFFF),如果您可以确保该字符串永远不会从程序中的任何位置发送而不删除此代码点。如Ch。中所述。 Unicode标准中的16个Special Areas and Format Characters非字符代码点保留供应用程序内部使用,不应在文本交换中使用。
答案 1 :(得分:0)
我建议你不要在行的开头使用奇怪的字符。你可以实现这样的东西:
<script type="text/javascript">
function LocalizationSet(){};
LocalizationSet.prototype.localizationItems = [];
LocalizationSet.prototype.itemsNeedAttention = [];
LocalizationSet.prototype.setLocalization = function(langId, text)
{
this.localizationItems[langId] = text;
this.itemsNeedAttention[langId] = true;
}
LocalizationSet.prototype.getLocalization = function(langId)
{
return this.localizationItems[langId];
}
LocalizationSet.prototype.needsAttention = function(langId)
{
if(this.itemsNeedAttention[langId] == null)
{
return false;
}
return this.itemsNeedAttention[langId];
}
LocalizationSet.prototype.unsetAttentionFlags = function()
{
for(var it in this.itemsNeedAttention)
{
this.itemsNeedAttention[it] = false;
}
}
//Example
var set = new LocalizationSet();
set.setLocalization("en","Hello");
set.setLocalization("de","Willkommen");
alert(set.needsAttention("en"));
alert(set.needsAttention("de"));
set.unsetAttentionFlags();
alert(set.needsAttention("en"));
set.setLocalization("en","Hi");
alert(set.needsAttention("en"));
//Shows true,true,false,true
</script>