Web 前端本地化(四)

前面的三篇文章中,我们已经拥有了本地化所需的一些基本功能,但如果在无法精准匹配当前语言的情况下,如何寻找上一层级的语言包,则是获取语言文本的最重要的一环。为此,我们需要实现以下步骤。

  1. 尝试获取预期语言的对应文本,有的话则返回之,没有的话继续。
  2. 检查语言代号标识中是否包含短横线(-),有的话则继续,没有的话则返回从默认语言的语言包中检索的结果。
  3. 找到最后一个短横线。
  4. 删除该短横线后面的内容。
  5. 返回第一步,重新来一遍。

代码如下。

/**
  * Gets the string in local or specific language.
  * @param key  The template key.
  * @param useKeyInsteadOfUndefined  true if use key as result instead of undefined; otherwise, false.
  * @param lang  The opitonal ISO 639 code string for a sepecific one.
  */
Local.prototype.getString = function (key, useKeyInsteadOfUndefined, lang) {
    var langCode = !lang ? Local.lang() : lang;
    if (!langCode || langCode == "") langCode = this.defaultLang;
    var str = this.specificString(langCode, key);
    if (!!str || typeof str !
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值