## switch标签
用法:
```
<switch name="变量">
<case value="值1" break="0或1,默认 break">输出内容1</case>
<case value="值2">输出内容2</case>
<default />默认情况
</switch>
```
使用方法如下:
```
<switch name="user_id">
<case value="1">value1</case>
<case value="2">value2</case>
<default />default
</switch>
```
其中name属性可以使用函数以及系统变量,例如:
```
<switch name="Think.get.userId|abs">
<case value="1">admin</case>
<default />default
</switch>
```
对于case的value属性可以支持多个条件的判断,使用”|”进行分割,例如:
```
<switch name="Think.get.type">
<case value="gif|png|jpg">图像格式</case>
<default />其他格式
</switch>
```
表示如果$_GET["type"] 是gif、png或者jpg的话,就判断为图像格式。
Case标签还有一个break属性,表示是否需要break,默认是会自动添加break,如果不要break,可以使用:
```
<switch name="Think.get.user_id">
<case value="1" break="0">admin</case>
<case value="2">admin2</case>
<default />default
</switch>
```
也可以对case的value属性使用变量,例如:
```
<switch name="user_id">
<case value="$adminId">admin</case>
<case value="$memberId">member</case>
<default />default
</switch>
```
使用变量方式的情况下,不再支持多个条件的同时判断。
简洁的用法
```
<switch $User.userId>
<case $adminId>admin</case>
<case $memberId>admin2</case>
</switch>
```
## IF标签
用法示例:
```
<if condition="($name == 1) OR ($name > 100) "> value1
<elseif condition="$name eq 2"/>value2
<else /> value3
</if>
```
除此之外,我们可以在condition属性里面使用php代码,例如:
```
<if condition="strtoupper($user['name']) neq 'THINKPHP'">ThinkPHP
<else /> other Framework
</if>
```
condition属性可以支持点语法和对象语法,例如: 自动判断user变量是数组还是对象
```
<if condition="$user.name neq 'ThinkPHP'">ThinkPHP
<else /> other Framework
</if>
```
或者知道user变量是对象
```
<if condition="$user:name neq 'ThinkPHP'">ThinkPHP
<else /> other Framework
</if>
```
由于if标签的condition属性里面基本上使用的是php语法,尽可能使用判断标签和Switch标签会更加简洁,原则上来说,能够用switch和比较标签解决的尽量不用if标签完成。因为switch和比较标签可以使用变量调节器和系统变量。如果某些特殊的要求下面,IF标签仍然无法满足要求的话,可以使用原生php代码或者PHP标签来直接书写代码。
简洁的用法
```
<if condition="表达式">
<if (表达式)>
<if 表达式>
```
这三种写法结果是一样的
## 范围判断
范围判断标签包括in notin between notbetween四个标签,都用于判断变量是否中某个范围。
## IN和NOTIN
用法: 假设我们中控制器中给id赋值为1:
```
$id = 1;
$this->assign('id',$id);
```
我们可以使用in标签来判断模板变量是否在某个范围内,例如:
```
<in name="id" value="1,2,3">
id在范围内
</in>
```
最后会输出:id在范围内。
如果判断不在某个范围内,可以使用notin标签:
```
<notin name="id" value="1,2,3">
id不在范围内
</notin>
```
最后会输出:id不在范围内。
可以把上面两个标签合并成为:
```
<in name="id" value="1,2,3">
id在范围内
<else/>
id不在范围内
</in>
```
name属性还可以支持直接判断系统变量,例如:
```
<in name="Think.get.id" value="1,2,3">
$_GET['id'] 在范围内
</in>
```
更多的系统变量用法可以参考系统变量部分。
value属性也可以使用变量,例如:
```
<in name="id" value="$range">
id在范围内
</in>
```
$range变量可以是数组,也可以是以逗号分隔的字符串。
value属性还可以使用系统变量,例如:
```
<in name="id" value="$Think.post.ids">
id在范围内
</in>
```
## BETWEEN 和 NOTBETWEEN
可以使用between标签来判断变量是否在某个区间范围内,可以使用:
```
<between name="id" value="1,10">
输出内容1
</between>
```
同样,也可以使用notbetween标签来判断变量不在某个范围内:
```
<notbetween name="id" value="1,10">
输出内容2
</notbetween>
```
也可以使用else标签把两个用法合并,例如:
```
<between name="id" value="1,10">
输出内容1
<else/>
输出内容2
</between>
```
当使用between标签的时候,value只需要一个区间范围,也就是只支持两个值,后面的值无效,例如
```
<between name="id" value="1,3,10">
输出内容1
</between>
```
实际判断的范围区间是1~3,而不是1~10,也可以支持字符串判断,例如:
```
<between name="id" value="A,Z">
输出内容1
</between>
```
name属性可以直接使用系统变量,例如:
```
<between name="Think.post.id" value="1,5">
输出内容1
</between>
```
value属性也可以使用变量,例如:
```
<between name="id" value="$range">
输出内容1
</between>
```
变量的值可以是字符串或者数组,还可以支持系统变量。
```
<between name="id" value="$Think.get.range">
输出内容1
</between>
```
## PRESENT NOTPRESENT标签
present标签用于判断某个变量是否已经定义,用法:
```
<present name="name">
name已经赋值
</present>
```
如果判断没有赋值,可以使用:
```
<notpresent name="name">
name还没有赋值
</notpresent>
```
可以把上面两个标签合并成为:
```
<present name="name">
name已经赋值
<else />
name还没有赋值
</present>
```
present标签的name属性可以直接使用系统变量,例如:
```
<present name="Think.get.name">
$_GET['name']已经赋值
</present>
```
## EMPTY NOTEMPTY 标签
empty标签用于判断某个变量是否为空,用法:
```
<empty name="name">
name为空值
</empty>
```
如果判断没有赋值,可以使用:
```
<notempty name="name">
name不为空
</notempty>
```
可以把上面两个标签合并成为:
```
<empty name="name">
name为空
<else />
name不为空
</empty>
```
name属性可以直接使用系统变量,例如:
```
<empty name="Think.get.name">
$_GET['name']为空值
</empty>
```
## DEFINED 标签
DEFINED标签用于判断某个常量是否有定义,用法如下:
```
<defined name="NAME">
NAME常量已经定义
</defined>
```
name属性的值要注意严格大小写
如果判断没有被定义,可以使用:
```
<notdefined name="NAME">
NAME常量未定义
</notdefined>
```
可以把上面两个标签合并成为:
```
<defined name="NAME">
NAME常量已经定义
<else />
NAME常量未定义
</defined>
```
- 序言
- 基础
- 安装ThinkCMF
- 为了更爽
- 目录结构
- 入口文件
- 第三方库
- 开发规范
- 数据库规范
- 调试模式
- URL访问
- 应用
- 配置
- 路由
- 控制器
- 控制器定义
- 控制器模板赋值
- 控制器模板渲染
- 前台控制器
- 前台用户控制器
- 后台控制器
- 跳转,AJAX返回和重定向
- URL生成
- 请求
- 请求信息
- 输入变量
- 请求类型
- 获取请求头信息
- 伪静态
- 更多
- 系统函数
- cmf_auth_check 用户权限检查
- cmf_captcha_check图片验证码验证
- cmf_check_mobile 检查手机号
- cmf_check_user_action 用户访问控制
- cmf_check_verification_code 数字验证码检查
- cmf_clear_cache清空系统缓存
- cmf_clear_verification_code 清除数字验证码
- cmf_compare_password 用户密码比较
- cmf_current_lang 判断当前语言包
- cmf_generate_user_token生成用户token
- cmf_get_admin_style 获取后台风格
- cmf_get_content_images 获取HTML图片
- cmf_get_current_admin_id 登录管理员ID
- cmf_get_current_admin_theme获取当前后台模板
- cmf_get_current_theme获取前台当前模板
- cmf_get_current_user 获取登录用户信息
- cmf_get_current_user_id 登录用户ID
- cmf_get_domain返回带协议的域名
- cmf_get_file_download_url 获取文件下载链接
- cmf_get_file_extension 获取文件扩展名
- cmf_get_image_url 获取图片 URL
- cmf_get_option 获取系统配置
- cmf_get_plugin_class 获取插件类名
- cmf_get_plugin_config获取插件配置
- cmf_get_root 网站根目录
- cmf_get_site_info 获取网站信息
- cmf_get_theme_path获取前台模板根目录
- cmf_get_upload_setting获取上传配置
- cmf_get_user_avatar_url 获取用户头像URL
- cmf_get_verification_code 生成数字验证码
- cmf_is_android 判断是否为安卓手机
- cmf_is_ios 判断是否为ios访问
- cmf_is_ipad 判断是否为ipad访问
- cmf_is_iphone 判断是否为iphone访问
- cmf_is_mobile 判断是否为手机
- cmf_is_user_login 判断用户是否登录
- cmf_is_wechat 判断是否为微信
- cmf_password 密码加密
- cmf_plugin_url 插件URL生成
- cmf_random_string随机字符串生成
- cmf_replace_content_file_url 替换编辑器文件地址
- cmf_scan_dir 替代scan_dir的方法
- cmf_send_email 发送邮件
- cmf_set_dynamic_config 设置动态配置
- cmf_set_option 设置系统配置
- cmf_split_sql 切分SQL文件
- cmf_update_current_user 更新当前用户信息
- cmf_url_encode 生成base64的url
- cmf_verification_code_log 验证码发送日志
- cmf_version获取版本号
- get_client_ip 获取客户端IP地址
- hook 添加钩子
- 数据库
- 数据库配置
- 添加数据
- 更新数据
- 查询数据
- 删除数据
- 事务操作
- 更多数据库操作
- 模型
- 模型定义
- 添加数据
- 更新数据
- 查询数据
- 删除数据
- 应用
- 应用的概念
- 应用开发流程
- 导航共享
- 几个重要基类
- 后台菜单注解
- 用户操作配置
- URL 规则配置
- 应用第三方库
- API
- 规范
- 状态码说明
- 版本号
- 资源控制器模板
- 成功返回
- 错误返回
- API路由
- API基类控制器
- API应用开发流程
- API第三方库
- 模板
- 模板常量
- 模板标签
- 变量输出
- 系统变量
- 请求参数
- 使用函数
- 使用默认值
- 使用运算符
- 三元运算
- 原样输出
- 模板注释
- 模板目录
- 包含文件
- 模板布局
- 模板继承
- 网站信息
- 内置标签
- 循环输出标签
- 比较标签
- 条件判断
- 标签嵌套
- 原生PHP
- 定义标签
- CMF标签
- 导航标签
- 子导航标签
- 验证码标签
- 幻灯片标签
- 钩子标签
- 友情链接标签
- 分页标签
- 傻瓜式模板
- 什么是傻瓜式模板
- 模板描述文件
- 模板文件配置
- 模板变量类型
- 模板变量数据源
- 导航模板数据源
- 导航菜单模板数据源
- 幻灯片模板数据源
- 模板切换
- 插件
- 插件钩子
- 核心钩子
- 前台模板钩子
- 后台钩子
- send_mobile_verification_code
- comment
- guestbook
- admin_dashboard
- switch_theme
- admin_login
- admin_init
- home_init
- 插件类主文件
- 插件开发流程
- 插件配置
- 插件控制器
- 插件后台管理控制器
- 插件后台菜单
- 插件视图
- 插件数据库模型
- 插件多语言
- 插件API控制器
- 插件第三方库
- 插件URL生成
- 前端
- Wind.js
- 前端组件
- js-ajax-form
- js-ajax-delete
- js-ajax-dialog-btn
- js-count-btn
- js-date
- js-datetime
- js-bootstrap-date
- js-bootstrap-datetime
- 专题
- 缓存
- Session
- Cookie
- 分页
- 验证码
- 文件上传
- 第三方扩展
- Swoole
- 附录
- 升级日志
- 升级指导