douluan4644 2018-07-18 17:23
浏览 17
已采纳

PHP E_NOTICE最佳实践 - 检查值的未定义var是不是很糟糕?

With E_NOTICE error messages enabled, PHP doesn't like the following code, unless the variables $mdDialog and $mdToast have already been defined:

if ($mdDialog || $mdToast) {
    $ngMaterial = true;
}

To avoid E_NOTICE error, I must write:

if (isset($mdDialog) || isset($mdToast)) {
    $ngMaterial = true;
}

The problem is that, with the above code, if I have a $mdDialog = false; line somewhere earlier, the statement will be truthy, which is not the idea. To avoid this, I'd have to write:

if ((isset($mdDialog) && $mdDialog) || (isset($mdToast) && $mdToast)) {
    $ngMaterial = true;
}

And this is sooo much longer and feels excessive, only to avoid the E_NOTICE message.

So, the question is, should I care about these E_NOTICE messages? Is there anything bad with checking the value of a variable that may not exist?

  • 写回答

3条回答 默认 最新

  • 普通网友 2018-07-18 17:31
    关注

    empty can be useful in this case. Like below:

    if (!empty($mdDialog) || !empty($mdToast)) {
        $ngMaterial = true;
    }
    

    Read more about empty.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?