繁体   English   中英

我可以使用哪个unicode字符来“标记”字符串?

[英]What unicode character I can use to “flag” a string?

我想代表一个具有多个文本属性的对象,每个对象代表相同的文本值,但使用不同的语言。 如果用户修改单个字段,则应该修改其他字段,而我正在考虑在其他字段的字符串开头添加单个Unicode字符,然后检查是否需要注意的字段,我只是必须检查obj.text_prop[0]的值。

我可以为此使用哪个Unicode字符? 理想情况下,它将是不可打印的,并且在JS和JSON中受支持。

这种标记应该以其他方式在字符级别以外的协议级别上进行。 例如,考虑将每种语言版本作为对象而不是字符串。 这样,除了包含字符串的属性之外,该对象还可以具有诸如needsAttention之类的属性。

但是,如果您需要将此类信息嵌入到字符串中,则可以使用ZERO WIDTH SPACE U + 200B。 因此,这意味着有换行的机会,但在此不应打扰。 主要问题可能是IE的旧版本可能将其显示为一个小矩形。

另外,如果可以确保在不删除该代码点的情况下,从不将字符串从程序中发送到任何地方,则可以使用非字符代码点,例如U + FFFF。 如Ch。 Unicode标准, 特殊区域和格式字符中的16个非字符代码点保留供应用程序内部使用,切勿在文本交换中使用。

我建议您不要在行首使用奇怪的字符。 您可以实现以下内容:

<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>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM