首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >检查标准内置对象是否可用

检查标准内置对象是否可用
EN

Stack Overflow用户
提问于 2019-03-06 19:28:27
回答 1查看 40关注 0票数 1

我正在开发一个React.js web应用程序,其中包含使用Intl (国际化对象)的数据表。以下错误仅在尝试在旧的Safari浏览器上加载应用程序时出现。

这是当前用于检查Intl是否可用的方法,如果不可用,则返回到localCompare()

代码语言:javascript
复制
function getCollatorComparator() { 
    if (Intl) return new Intl.Collator(void 0, { numeric: !0, sensitivity: "base" }).compare;
    return function(e, t) {
        return (e + "").localeCompare(t) 
    } 
}

上面的代码在传统的Safari (iOS 9)上不起作用。

如何检查Intl是否可用?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-03-06 19:42:48

当你执行if(Intl)时,你会得到一个错误,因为没有定义Intl,类似于这样:

代码语言:javascript
复制
if(foo) { // foo not defined -> thus crash
  console.log("foo");
} else {
  console.log("bar"); // not executed
}

但是,如果您使用typeof,您可以检查以前是否没有声明变量:

代码语言:javascript
复制
if(typeof foo !== "undefined") { // no crash (foo is undefined)
  console.log("foo");
} else {
  console.log("bar"); // bar is outputted
}

因此,不用使用(如果没有定义Intl就会抛出一个错误):

代码语言:javascript
复制
if(Intl) // code...

您可以使用:

代码语言:javascript
复制
if(typeof Intl !== "undefined") // code...
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55022017

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档