thinkphp中实例下CURP中的ACtion中index,delete,edit方法用的M(“Form”)方法实例化模型,而insert,update方法用D方法实例化Model模型。
两个有共同点都是实例化对象用的。
但是在使用时两者却不一样,为什么?
先看看代码
函数M:
view plaincopy to clipboardprint?
function M($name = '', $class = 'Model')
{
static $_model = array();
if (!isset($_model[$name . '_' . $class]))
// 默认也就是 new Model($name)
$_model[$name . '_' . $class] = new $class($name);
//返回实例化对象
return $_model[$name . '_' . $class];
}
function M($name = '', $class = 'Model')
{
static $_model = array();
if (!isset($_model[$name . '_' . $class]))
// 默认也就是 new Model($name)
$_model[$name . '_' . $class] = new $class($name);
//返回实例化对象
return $_model[$name . '_' . $class];
}
$_model[$name . '_' . $class] = new $class($name);
默认也就是 new Model($name)
也就是说 M返回的是Model的对象
如果$name不为空 那么$name的意义也就是代表数据库的表名(这个以后说)
通过直接实例化Model方法(ThinkPHP基类)来动态的实例化一个Model对象,即使这个对应的Model文件不存在。
再来看D方法:
view plaincopy to clipboardprint?
function D($name = '', $app = '')
{
static $_model = array();
if (emptyempty($name))
//$name为空 作用就等同 函数M();
return new Model;
if (emptyempty($app))
//默认模块名称 在Common/convention.php中定义 =@
$app = C('DEFAULT_APP');
//如果已经存在对象 直接返回
if (isset($_model[$app . $name]))
return $_model[$app . $name];
$OriClassName = $name;
//如果$name参数是以 @.**.模块名 这种参数传递的话
if (strpos($name, '.'))
{
$array = explode('.', $name);
//$name=模块名
$name = array_pop($array);
$className = $name . 'Model';
//导入Model模块所在的文件
import($app . '.Model.' . implode('.', $array) . '.' . $className);
}
//直接导入
else
{
$className = $name . 'Model';
import($app . '.Model.' . $className);
}
//实例化对象返回
if (class_exists($className))
{
$model = new $className();
} else
{
$model = new Model($name);
}
$_model[$app . $OriClassName] = $model;
return $model;
}
function D($name = '', $app = '')
{
static $_model = array();
if (empty($name))
//$name为空 作用就等同 函数M();
return new Model;
if (empty($app))
//默认模块名称 在Common/convention.php中定义 =@
$app = C('DEFAULT_APP');
//如果已经存在对象 直接返回
if (isset($_model[$app . $name]))
return $_model[$app . $name];
$OriClassName = $name;
//如果$name参数是以 @.**.模块名 这种参数传递的话
if (strpos($name, '.'))
{
$array = explode('.', $name);
//$name=模块名
$name = array_pop($array);
$className = $name . 'Model';
//导入Model模块所在的文件
import($app . '.Model.' . implode('.', $array) . '.' . $className);
}
//直接导入
else
{
$className = $name . 'Model';
import($app . '.Model.' . $className);
}
//实例化对象返回
if (class_exists($className))
{
$model = new $className();
} else
{
$model = new Model($name);
}
$_model[$app . $OriClassName] = $model;
return $model;
}
具体注释已经在代码里面了。
A快速实例化Action类库
B执行行为类
C配置参数存取方法
D快速实例化Model类库
F快速简单文本数据存取方法
L 语言参数存取方法
M快速高性能实例化模型
R快速远程调用Action类方法
S快速缓存存取方法
U URL动态生成和重定向方法
W 快速Widget输出方法
D函数实例化的是你当前项目的Lib/Model下面的模块。
如果该模块不存在的话,直接返回实例化Model的对象(意义就与M()函数相同)。
而M只返回,实例化Model的对象。它的$name参数作为数据库的表名来处理对数据库的操作。
通俗点说:
D就是实例化一个基于Model文件的Model。
M则是通过直接实例化Model方法(ThinkPHP基类)来动态的实例化一个Model对象,即使这个对应的Model文件不存在。
再通俗一点说:
M实例化参数是数据库的表名。
D实例化的是你自己在Model文件夹下面建立的模型文件。
D就是在你没有定义模型的时候,系统自动帮你定义一个模型,这样你才进行简单的数据输入或者输出。
每一个Action文件都应该对应Model文件的,如果你定义了Model的话,
如:$Form = D("User")就可以改成$Form = new LoginModel();(Login是指你的模型文件名)。
D()和M()方法的区别:
D和M的区别主要在于
M方法不需要创建模型类文件,M方法不会读取模型类,所以默认情况下自动验证是无效的,但是可以通过动态赋值的方式实现
而D方法必须有创建模型类。
我们可以用下面两种方法去创建一个数据表的映射对象
第一种:$Test = D('Test')
第二种:$Test = new Model('Test')
虽然这两种都可以对数据进行select,insert,delete,udpate操作,在数据验证上有很大的不同,
用第一种方式实例一个模型就会有数据检查功能,如果 title 没有填写的话就会提示 “请输入标题” (这个是tp提供的一个自动验证功能,当然也需要在相应的model中定义好验证条件);
如果用第二种就没有了·····
还有1个区别就是当用了$trueTableName后,必须用$test=d('test'),表示查询的是test表,
如果用的是$test=m('test'),那么都表示查询的数据边是think_test。