CodeIgniter框架Router.php源码有问题吗?

发布于 2022-09-04 04:34:16 字数 796 浏览 13 评论 0

在ci框架的systemcoreRouter.php文件中,line132行开始代码如下:

    is_array($routing) && isset($routing['directory']) && $this->set_directory($routing['directory']);
    $this->_set_routing();

    // Set any routing overrides that may exist in the main index file
    if (is_array($routing))
    {
        empty($routing['controller']) OR $this->set_class($routing['controller']);
        empty($routing['function'])   OR $this->set_method($routing['function']);
    }

首先,第一行的:
is_array($routing) && isset($routing['directory']) && $this->set_directory($routing['directory']);
我不确定这样写是否有意义,这样一行表达式的结果(true or false)不添加判断的话,得到的结果(true or false)有什么用意呢?
另外在if判断语句里,使用empty判断两个结果,我也认为没有意义,如果不去做判断的话,这样写有什么想法吗?
还请各位指教.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

忘羡 2022-09-11 04:34:16
is_array($routing) && isset($routing['directory']) && $this->set_directory($routing['directory']);

&&这个符号知道是 true + true 对把?
也就是说 第一个第二个 一定都要执行成功才会执行第三个,这三个都要执行成功,否这就不执行。我们可以换一个写法:

if (is_array($routhing) && isset($routing['directory'])) {
    $this->set_directory($routing['directory']);
}

思路很清晰了把?

为什么要这样做 && 这样做?

1、因为不涉及复杂的语句
2、简洁
3、直观、可读性强
装迷糊 2022-09-11 04:34:16
// && vs ||
!isset($a) && $a=1;
echo $a;//1
isset($a) || $a =2;
echo $a;//1
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文