【问题标题】:Checking and setting default variable in Javascript在 Javascript 中检查和设置默认变量
【发布时间】:2012-12-10 11:51:11
【问题描述】:

假设您有一个对象 TRACK,用于跟踪

TRACK = {};
TRACK.pageName = pageName || TRACK.buildPageName();

如果在它之前的某个地方有这个就可以了:

var pageName = "Home";

让我们假设解决这个问题的方法是:

TRACK.pageName = (typeof pageName != 'undefined' ? pageName : TRACK.buildPageName());

对大型 javascript 对象执行此操作是否有更好的做法?

【问题讨论】:

  • 我认为“TRACK.pageName = pageName || TRACK.buildPageName()”是完全可以接受的。

标签: javascript oop object


【解决方案1】:

如果您在浏览器中,您可以使用window.pageName 来检查 pageName 值。

TRACK.pageName = window.pageName !== undefined ? pageName : TRACK.buildPageName();

但这并不是真正“更好”的做法。这只是第二种方法。使用typeof 也可以。

【讨论】:

  • 谢谢 - 在使用速记语法之前,我主要是在寻找有关如何处理空变量的更好做法。
【解决方案2】:

你的例子:

TRACK.pageName = pageName || TRACK.buildPageName();

是正确的,但如果你想与undefined 一起露营,这里有一种方法:

if (pageName !== undefined){...}

【讨论】:

  • 你不能那样做。如果pageName 不存在,您将收到类似pageName is undefined 的错误。除了typeof 运算符之外,您不能在 javascript 中使用未声明/未知的变量。
【解决方案3】:

我认为,您可以在 TRACK.buildPageName() 中实现这个 if 语句。 如果 pageName 是全局变量,您可以从 TRACK.buildPageName() 中访问它

{
...
    buildPageName: function() {
        this.pageName = (typeof pageName != 'undefined' ? pageName : TRACK.innerBuildPageName());
    }
}

多亏了这个,你可以隐藏和执行这个 if 语句一次。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2021-02-17
    • 2020-03-27
    • 2015-01-04
    • 2015-08-18
    • 2012-09-06
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多