【问题标题】:JavaScript check if timezone name valid or notJavaScript 检查时区名称是否有效
【发布时间】:2017-10-22 06:39:41
【问题描述】:

有没有办法在不使用外部库的情况下检查时区名称在 JavaScript 中是否有效?

当用户在文本字段中输入时区名称时,我想验证时区是否有效?

我知道我们可以使用时刻时区库轻松做到这一点。但我不想使用任何额外的库。我正在寻找纯 JavaScript 方式。

isValidTimeZone(name) {
//return true/false  
}

isValidTimeZone('Asia/Colombo'); //returns true
isValidTimeZone('America/Los_Angeles'); //returns true
isValidTimeZone('MyTimeZone/ME'); //returns false

【问题讨论】:

  • 根据友好的位置名称(如您在问题中显示的那样),时区被视为无效,它们根据时区偏移量有效。 stackoverflow.com/questions/22609927/…
  • 用户输入时区名称(例如:亚洲/科伦坡)。稍后我需要在 Highcharts 中使用它。所以需要验证这一点。用户不会输入 +05:30。
  • 是什么让时区对您有效? America/Anaheim 有效吗?因为我不认为你的意思是“大陆/城市名称”格式的任何东西都是自动有效的。你必须有一些数据库来测试。
  • 您想自己维护this data吗?为了避免使用图书馆,似乎很麻烦。
  • 它们不仅仅是“友好”的名称,它们是 tz 数据库中的标识符。名单在这里:en.wikipedia.org/wiki/List_of_tz_database_time_zones

标签: javascript timezone timezone-offset


【解决方案1】:

在完全支持 ECMA-402(ECMAScript 国际化 API)中的 IANA 时区标识符的环境中,您可以尝试在 DateTimeFormat(或 toLocaleString 的选项中)使用时区,它会抛出一个如果它不是有效的时区,则异常。您可以使用它来测试有效性,但只能在支持它的环境中使用。

function isValidTimeZone(tz) {
    if (!Intl || !Intl.DateTimeFormat().resolvedOptions().timeZone) {
        throw new Error('Time zones are not available in this environment');
    }

    try {
        Intl.DateTimeFormat(undefined, {timeZone: tz});
        return true;
    }
    catch (ex) {
        return false;
    }
}

// Usage:
isValidTimeZone('America/Los_Angeles') // true
isValidTimeZone('Foo/Bar') // false

如果您无法确定自己的环境,那么最好的方法是使用时刻时区

!!moment.tz.zone('America/Los_Angeles') // true
!!moment.tz.zone('Foo/Bar') // false

当然,您始终可以提取自己的时区名称数组(可能使用 moment.tz.names() 并针对它进行测试。

【讨论】:

    【解决方案2】:

    在打字稿中你也可以用更简洁的方式来做

        public static isValidTimezone(timezone: string): boolean {
                return moment.tz.zone(timezone) != null;
            }
    

    你还需要导入

    import moment = require("moment-timezone");
    

    【讨论】:

      猜你喜欢
      • 2020-08-20
      • 2015-02-26
      • 1970-01-01
      • 2010-10-12
      • 1970-01-01
      • 2020-10-15
      • 1970-01-01
      • 1970-01-01
      • 2017-10-19
      相关资源
      最近更新 更多