不灭的焱

革命尚未成功,同志仍须努力下载JDK17

作者:Albert.Wen  添加时间:2012-06-16 16:04:13  修改时间:2024-04-14 17:25:46  分类:PHP库/系统/微信  编辑

ThinkPHP U方法

U 方法是 ThinkPHP 内置的一个快捷方法,可以根据系统 URL 模式配置动态的生成智能的 URL 地址。

由于 ThinkPHP 支持各种不同的 URL 模式,另外还有分组模式,因此当环境发生变化时,有时候可能会改变 URL 模式,而 U 方法正是解决不同配置情况下的 URL 统一问题。除了动态生成 URL 以自适应系统配置外,U 方法还有一个好处是可以自动加上伪静态后缀。

U方法语法

U 方法的定义规则如下:

U('[项目://][路由@][分组名-模块/]操作?参数1=值1[&参数N=值N]')
// 或者:
U('[项目://][路由@][分组名-模块/]操作',array('参数1'=>'值1' [,'参数N'=>'值N']))

U方法实例

假设当前为 Index 模块的 index 操作,生成当前模块的 list 操作 URL:

U('list?cat_id=1&status=1')

生成的 URL 为相对链接:index.php/Index/list/cat_id/1/status/1

模板中使用 U 方法

U 方法实际属于 ThinkPHP 系统函数,可以直接使用,更多可参见《ThinkPHP 模板中使用函数》。通常 U 方法用于模板生成超链接:

<a href="{:U('list?cat_id=1&status=1')}">超链接字符</a>

生成 URL 后实际的 html 代码为:

<a href="index.php/Index/list/cat_id/1/status/1">超链接字符</a>

U 方法中使用变量,需要用 . 连接符:

<a href="{:U('list?cat_id='.$catList['cat_id'].'&status=1')}">超链接字符</a>

各种 URL 模式下的对比

U 方法根据 URL 模式的不同而自适应的生成不同的 URL 格式,如上面例子在各模式下生成的 URL 对比如下:

  • 普通兼容模式:index.php?m=Index&a=list&cat_id=1&status=1
  • PATHINFO 模式:index.php/Index/list/cat_id/1/status/1
  • REWRITE 模式:Index/list/cat_id/1/status/1
  • REWRITE 模式,伪静态后缀为 .html:Index/list/cat_id/1/status/1.html
  • REWRITE 模式,使用 - 分隔符与 .html 后缀:Index-list-cat_id-1-status-1.html

常见 U 方法使用例子

// 当前模块 list 操作
U('list?cat_id=1&status=1')
// 其他模块操作
U('Blog/read?id=1') // 生成Blog模块的read操作,并且id为1的URL地址
// 其他分组
U('Admin-User/view?uid=1') // 生成Admin分组的User模块的view操作的URL地址

U 方法也可以在操作中使用,与使用普通函数用法一致(不需要 $this->)。