本篇文章给大家带来了关于thinkphp的相关知识,其中主要介绍了关于字母函数的相关问题,包括了A、B、C、D方法等等,希望对大家有帮助。
推荐学习:《thinkphp学习》
A 方法用于在内部实例化控制器,调用格式:
// A('[项目://][分组/]模块','控制器层名称')$User = A('User');$User = A('Admin://User');
实例化控制器后,就可以调用该控制器中的方法,不过需要注意的情况是,在跨项目调用的情况下,如果你的操作方法 有针对当前控制器的特殊变量操作,会有一些未知的问题,所以,一般来说,官方建议需要公共调用的控制器层单独开发,不要有太多的依赖关系。
B 方法这是随着行为应运而生的新生函数,可以执行某个行为,例如
B('app_begin');
就是在项目开始之前,执行这个行为定义的所有函数。支持 2 个参数,第二个参数支持需要接受一个数组,例如
B('app_begin', ["name" => "tdweb","time"=>time()]);C 方法
C 方法是 Think 用于设置、获取,以及保存配置参数的方法,使用频率较高。
动态设置配置参数,配置参数不区分大小写,但是建议保持统一大写的配置定义规范。
C('DB_NAME','think');
支持二级配置参数的设置,配置参数不建议超过二级。例如:
C('USER.USER_ID',8);
如果要设置多个参数,可以使用批量设置,例如:
$config['user_id'] = 1;$config['user_type'] = 1;C($config);
如果传入的配置参数为空,表示获取全部的参数:
$config = C();D 方法
D 方法应该是用的比较多的方法了,用于实例化自定义模型类,是 Think 框架对 Model 类实例化的一种封装,并实现了单例模式,支持跨项目和分组调用,调用格式如下:
D('[项目://][分组/]模型','模型层名称')
方法的返回值是实例化的模型对象。
D 方法可以自动检测模型类,如果存在自定义的模型类,则实例化自定义模型类,如果不存在,则会实例化 Model 基类,同时对于已实例化过的模型,不会重复去实例化。
D 方法最常用的用法就是实例化当前项目的某个自定义模型,例如:
// 实例化 User 模型$User = D('User');F 方法
F 方法其实是 S 方法的一个子集功能,仅用于简单数据缓存,并且只能支持文件形式,不支持缓存有效期,因为采用的是返回方式,所以其效率较 S 方法较高,因此我们也称之为快速缓存方法。
F 方法的特点是:
- 简单数据缓存;
- 文件形式保存;
- 采用返回数据方式加载缓存;
- 支持子目录缓存以及自动创建;
- 支持删除缓存和批量删除;
写入和读取缓存
F('data','test data');
默认的保存起始路径是 DATA_PATH(该常量在默认配置位于 RUNTIME_PATH.‘Data/’ 下面),也就是说会生成文件名为 DATA_PATH.‘data.’ 的缓存文件。
注意:确保你的缓存标识的唯一,避免数据覆盖和冲突。
下次读取缓存数据的时候,使用:
$Data = F('data');
我们可以采用子目录方式保存,例如:
F('user/data',$data); // 缓存写入F('user/data'); // 读取缓存
就会生成 DATA_PATH.‘user/data.’ 缓存文件,如果 user 子目录不存在的话,则会自动创建,也可以支持多级子目录,例如:
F('level1/level2/data',$data);
如果需要指定缓存的起始目录,可以用下面的方式:
F('data',$data,TEMP_PATH);
删除缓存
F('data',NULL);G 方法
G 方法的作用包括标记位置和区间统计两个功能,下面来看下具体用法:
标记位置G 方法的第一个用法就是标记位置,例如:
G('begin');
表示把当前位置标记为 begin 标签,并且记录当前位置的执行时间,如果环境支持的话,还能记录内存占用情况。可以在任何位置调用 G 方法标记。
运行时间统计标记位置后,我们就可以再次调用 G 方法进行区间统计了,例如:
G('begin'); // ...其他代码段G('end'); // ...也许这里还有其他代码 // 进行统计区间echo G('begin','end').'s';
G(‘begin’,‘end’) 表示统计 begin 位置到 end 位置的执行时间(单位是秒),begin 必须是一个已经标记过的位置,如果这个时候 end 位置还没被标记过,则会自动把当前位置标记为 end 标签,输出的结果类似于:
0.0056s
默认的统计精度是小数点后 4 位,如果觉得这个统计精度不够,还可以设置例如:
G('begin','end',6).'s';
内存开销统计
如果你的环境支持内存占用统计的话,还可以使用 G 方法进行区间内存开销统计(单位为 kb),例如:
echo G('begin','end','m').'kb';
第三个参数使用 m 表示进行内存开销统计,输出的结果可能是:
625kbI 方法
正如你所见到的一样,I 方法是 Thinkphp 众多单字母函数中的新成员,其命名来自于英文 Input(输入),主要用于更加方便和安全的获取系统输入变量,可以用于任何地方,用法格式如下:
I('变量类型.变量名',['默认值'],['过滤方法'])
变量类型是指请求方式或者输入类型,包括:
注意:变量类型不区分大小写。变量名则严格区分大小写。
默认值和过滤方法均属于可选参数。
L 方法L 方法用于启用多语言的情况下,设置和获取当前的语言定义。
调用格式:
L('语言变量',['语言值'])M 方法
M 方法用于实例化一个基础模型类,和 D 方法的区别在于:
- 不需要自定义模型类,减少 IO 加载,性能较好;
- 实例化后只能调用基础模型类(默认是 Model 类)中的方法;
- 可以在实例化的时候指定表前缀、数据库和数据库的连接信息;
D 方法的强大则体现在你封装的自定义模型类有多强,不过随着新版 Think 框架的基础模型类的功能越来越强大,M 方法也比 D 方法越来越实用了。
M 方法的调用格式:
M('[基础模型名:]模型名','数据表前缀','数据库连接信息')R 方法
R 方法用于调用某个控制器的操作方法,是 A 方法的进一步增强和补充。
R 方法的调用格式:
R('[项目://][分组/]模块/操作','参数','控制器层名称')
可以通过 R 方法在其他控制器里面调用这个操作方法(一般 R 方法用于跨模块调用)
$data = R('User/detail',array('5'));
官方的建议是不要在同一层多太多调用,会引起逻辑的混乱,被公共调用的部分应该封装成单独的接口,可以借助3.1的新特性多层控制器,单独添加一个控制器层用于接口调用
S 方法S 方法还支持对当前的缓存方式传入缓存参数,例如:
S('data',$Data,3600,'File',array('length'=>10,'temp'=>RUNTIME_PATH.'temp/'));T 方法
为了更方便的输出模板文件,新版封装了一个 T 函数用于生成模板文件名。
T([资源://][模块@][主题/][控制器/]操作,[视图分层])
T 函数的返回值是一个完整的模板文件名,可以直接用于 display 和 fetch 方法进行渲染输出。
U 方法U 方法用于完成对 URL 地址的组装,特点在于可以自动根据当前的 URL 模式和设置生成对应的 URL 地址,格式为:
U('地址','参数','伪静态','是否跳转','显示域名');
在模板中使用 U 方法而不是固定写死 URL 地址的好处在于,一旦你的环境变化或者参数设置改变,你不需要更改模板中的任何代码。
推荐学习:《thinkphp框架》
【文章原创作者响水网站建设公司 http://www.1234xp.com/xiangshui.html 欢迎留下您的宝贵建议】