[优化] [CI代码解读] $this->load->model() 问题


见上图

Home 控制器内加载了 menu目录下的 Menu_model和user/User_model 。 menu/Menu_model 又加载了 role/User_model

此时要注意了。看似 user/User_model role/User_model 毫无关系。但是出现了冲突。实际user/User_model 并没有被实例化。详细看代码

/system/core/Loader.php

$model = ucfirst($model); //首先还是CI一贯的大驼峰命名。首字母大写。 if ( ! class_exists($model, FALSE)) // 然后判断类是否存在。注意这里:判断是类如果不存在才执行if里面的内容。因为我这3个model内有2个model名字相同。但是目录不同。虽然是这// 样,但他并没有分开。这也是没用命名空间的问题。是一个典型问题。所以在就算在不同的目录。model的名称也不要相同。问题就在这里。下面的代码我也解释下吧。。 { foreach ($this->_ci_model_paths as $mod_path) // 然后循环下目录位置 { if ( ! file_exists($mod_path.'models/'.$path.$model.'.php')) // 查看这个model的文件在不在。不在就跳出程序了。 { continue; } require_once($mod_path.'models/'.$path.$model.'.php'); // 存在就引用。 if ( ! class_exists($model, FALSE)) // 这个引用后后看了下类名是否存在。不存在就抛出异常了。 { throw new RuntimeException($mod_path."models/".$path.$model.".php exists, but doesn't declare class ".$model); } break; } if ( ! class_exists($model, FALSE)) // 为何要一直判断这个存在不存在。没想通。 { throw new RuntimeException('Unable to locate the model you have specified: '.$model); } } elseif ( ! is_subclass_of($model, 'CI_Model')) // 如果上述的行为都不存在。那就奇怪了。所以最后看看是不是CI_MODEL里面的子类。如果也不是依旧报异常。 { throw new RuntimeException("Class ".$model." already exists and doesn't extend CI_Model"); } $this->_ci_models[] = $name; // 将自定义名称加入模型中 $CI->$name = new $model(); // 实例化对象并且赋值到你自定义的名称上 return $this; //返回本身

问题就是这个样子了。有什么问题或者哪里不对的可以留言。

最后修改:3年前
如果觉得我的文章对你有用,请随意赞赏

共有 0 条评论