首页 > 代码库 > 掌握Thinkphp3.2.0----内置标签

掌握Thinkphp3.2.0----内置标签

使用内置标签的时候,一定要注意闭合-----单标签自闭合,双标签对应闭合

标签的学习在于记忆和应用

一. 判断比较

1 //IF 语句的完整格式
2 <if condition="$user eq ‘蜡笔小新‘">
3 小新
4 <elseif condition="$user eq ‘黑崎一护‘" />
5 一护
6 <else />
7 错误
8 </if>
1 //condition 条件里可以使用 PHP 函数
2 <if condition="mb_substr($user,0,3,‘UTF-8‘) eq ‘蜡笔小‘">
3 //condition 条件里使用点语法,智能判断数组或对象
4 <if condition="$data.user eq ‘蜡笔小新‘">
5 //condition 条件里使用冒号语法,直接使用对象
6 <if condition="$data:user eq ‘蜡笔小新‘">
7 //condition 条件里使用系统变量
8 <if condition="$Think.get.user eq ‘蜡笔小新‘">

 switch语句

1 //name 的值和 IF 语句一样,可以是变量、数组、对象、函数或系统变量
2 <switch name="user">
3 <case value="http://www.mamicode.com/蜡笔小新">小新</case>
4 <case value="http://www.mamicode.com/黑崎一护">一护</case>
5 <default />错误
6 </switch>

默认情况下,case 会自动添加 break 语句防止穿透,如果你就是想要穿透,那么可以去除 break。当然,绝大部分不需要设置 break。

1 //去除 break
2 <case value="http://www.mamicode.com/蜡笔小新" break="0">小新</case>

 

比较标签,都能和else搭配

技术分享

1 //eq标签
2 <eq name="user" value="http://www.mamicode.com/1">相等<else/>不相等</eq>
3 //其他的标签和这个标题的用法基本相同不再赘述
4 //compare统一方法
5 <compare type="eq" name="user" value="http://www.mamicode.com/1">相等<else/>不相等</compare>

 

范围判断标签 in、notin、between、notbetween  

判断变量的标签  present -- notpresent  empty -- notempty    defined -- notdefined   

其实都可以和else搭配使用,也就说not*没有什么作用,至少实在效果上来说

 1 <present name="Think.get.user">$_GET[‘user‘]已赋值</present>
 2 //判断变量是否为空,空则输出
 3 <empty name="user">user 为空值</empty>
 4 //判断变量是否为空,不空则输出
 5 <notempty name="user">user不为空值</notempty>
 6 //判断变量是否为空,组合
 7 <empty name="user">
 8 user为空值
 9 <else />
10 user不为空值
11 </empty>
12 //判断变量是否为空,系统变量
13 <empty name="Think.get.user">$_GET[‘user‘]为空值</empty>
14 //判断常量是否定义,定义了输出
15 <defined name="APP_PATH">APP_PATH 常量已定义</defined>
16 //判断常量是否定义,没定义输出
17 <notdefined name="APP_PATH">APP_PATH 常量未定义</notdefined>
18 //判断常量是否定义,组合
19 <defined name="APP_PATH">
20 APP_PATH常量已定义
21 <else />
22 APP_PATH常量未定义
23 </defined>

 

 二.遍历循环   Volist 标签、Foreach 标签和 For 标签

Volist 标签

基本:

 <ul> <volist name="data" id="arr"> <li>{$arr.id} -- {$arr.user} -- {$arr.mail}</li> </volist> </ul> 

PS:这里的 name="data"中的 data 是控制器给模版定义的数据变量,要对应;这里
的 id="arr"中的 arr 是将要遍历循环的数组名,可以自定义。

各种属性:

 1 //offset 从第几条开始,起始值 0,length 共多少条
 2 <volist name="data" id="arr" offset="5" length="10">
 3 <li>{$arr.id} -- {$arr.user} -- {$arr.mail}</li>
 4 </volist>
 5 //mod 求当前余数,当前 index 除以 2 余 1,输出偶数
 6 <volist name="data" id="vo" mod="2">
 7 <eq name="mod" value="http://www.mamicode.com/1">
 8 <li>{$vo.id} -- {$vo.user} -- {$vo.mail}</li>
 9 </eq>
10 </volist>
11 //没有数据的情况下使用 empty 填充
12 <volist name="data" id="vo" empty="没有任何数据">
13 <li>{$vo.id} -- {$vo.user} -- {$vo.mail}</li>
14 </volist>
15 //empty 属性不支持 HTML 直接输入,但可以通过变量输出
16 $this->assign(‘empty‘, ‘<span style="color:red">没有任何数据</span>‘);
17 <volist name="data" id="vo" empty="$empty">
18 //通过 key 输出循环遍历的变量
19 <volist name="data" id="vo" key="k">
20 <li>{$k} -- {$vo.id} -- {$vo.user} -- {$vo.mail}</li>
21 </volist>
22 //没有指定 k,也可以用 i 变量输出
23 <li>{$i} -- {$vo.id} -- {$vo.user} -- {$vo.mail}</li>
24 //key 变量,可以直接输出索引值,从 0 开始
25 <li>{$key} -- {$vo.id} -- {$vo.user} -- {$vo.mail}</li>

 

foreach标签

Foreach 标签和 Volist 标签类似,只不过 Foreach 标签更加简单,没有额外属性。

//只支持 key 属性,但{$key}变量支持
<ul>
<foreach name="data" item="vo">
<ul>{$vo.id} -- {$vo.user}</ul>
</foreach>
</ul>

 

for标签就更简单了

1 //从 1 到 99 循环
2 <for start="1" end="100">
3 {$i}<br />
4 </for>
5 //完整形式
6 <for start="1" end="100" comparison="lt" step="2" name="k">
7 {$i}<br />
8 </for>

除了start和end必须值,还有三个可选值。comparison是大于还是小于,默认值为lt
(<) ;name是循环变量名,默认值为i;step是步进值,默认为1。

三.其他标签

 1 //在模版中定义变量, value 值可以为变量 ($user) 或系统变量 ($Think.get.user)
 2 <assign name="var" value="http://www.mamicode.com/123" />
 3 {$var}
 4 //在模版中定义常量, value 值可以为变量 ($user) 或系统变量 ($Think.get.user)
 5 <define name="MY_NAME" value="http://www.mamicode.com/Lee" />
 6 {$Think.const.MY_NAME}
 7 import 导入标签可以智能的导入 js 和 css 文件
 8 //常规引入方法
 9 <script type="text/javascript" src="http://www.mamicode.com/__PUBLIC__/js/index.js"></script>
10 <link rel="stylesheet" type="text/css"
11 href="http://www.mamicode.com/__PUBLIC__/css/index.css" />
12 //使用 import 导入,js 和 css 是目录
13 <import type="js" file="js.index" />
14 <import type="css" file="css.index" />
15 //使用 import 导入,basepath 修改默认路径
16 <import type="js" file="js.index" basepath="./Common" />
17 load 加载标签可以智能的加载 js 和 css 文件
18 //使用 load 加载
19 <load href="http://www.mamicode.com/__PUBLIC__/js/index.js" />
20 <load href="http://www.mamicode.com/__PUBLIC__/css/index.css" />
21 系统还提供了专用 js 和 css 标签,专门用于加载
22 //使用专用标签
23 <js href="http://www.mamicode.com/__PUBLIC__/js/index.js" />
24 <css href="http://www.mamicode.com/__PUBLIC__/css/index.css" />
 1 //使用 php 标签
 2 <php>
 3 $a = 1;
 4 $b = 2;
 5 echo $a + $b;
 6 </php>
 7 //使用 php 语法
 8 <?php
 9 $a = 1;
10 $b = 2;
11 echo $a + $b;
12 ?>
13 如果想原样输出标签极其内容,可以使用 literal 标签
14 //原样输出
15 <literal>
16 <php>echo 123;</php>
17 </literal>

 

掌握Thinkphp3.2.0----内置标签