Thinkphp中volist标签用于遍历数组,支持直接遍历、嵌套处理、空值判断、隔行样式控制及模板函数调用。

一、使用volist标签直接遍历数组
在thinkphp模板中,volist标签专用于遍历索引数组或关联数组,其底层通过PHP的foreach机制实现数据提取。当控制器传入的变量为一维或二维数组时,volist可直接按键值结构展开渲染。
1、在控制器中定义数组并赋值给模板变量:$this->assign(‘userList’, [[‘id’=>1,’name’=>’张三’],[‘id’=>2,’name’=>’李四’]]);
2、在模板中使用volist标签遍历:
姓名:{$user.name},ID:{$user.id}
3、volist支持offset、Length、key等属性,例如从第2条开始取3条:
立即学习“PHP免费学习笔记(深入)”;
二、嵌套volist处理多维数组
当传入模板的数据为三维及以上深度的数组(如分类-子分类-文章结构),需通过嵌套volist逐层展开,每层volist绑定独立的id标识符以避免变量冲突。
1、控制器传递嵌套数组:$this->assign(‘cateTree’, [[‘id’=>1,’title’=>’PHP’,’children’=>[[‘id’=>11,’title’=>’语法’],[‘id’=>12,’title’=>’函数’]]],[‘id’=>2,’title’=>’MySQL’,’children’=>[[‘id’=>21,’title’=>’索引’]]]]);
2、外层volist遍历一级分类:
{$cate.title}
3、内层volist遍历子项,使用不同的id名:
├─ {$child.title}
三、结合empty标签处理空数组情况
volist在遇到空数组或未定义变量时默认不渲染任何内容,但用户可能需要显示提示信息。此时需配合empty标签进行空值判断,确保前端体验一致。
1、在volist外部包裹empty标签:
暂无数据
{$item.value}
2、empty标签中的name属性必须与volist的name属性完全一致,且不能加引号或点号路径。
3、若数组存在但元素全为空字符串或NULL,empty仍会触发,因ThinkPHP的empty判断基于PHP empty()函数逻辑。
四、使用mod属性实现列表隔行样式控制
volist内置mod属性用于获取当前循环次数对指定数字取模的结果,常用于生成奇偶行不同class、插入分隔符或每N条添加一个容器块。
1、为奇数行添加特殊样式:
{$vo.title}
2、每3条数据包裹在一个div中:
{$it.name}
3、mod值从0开始计数,$it.i表示当前索引(从0起),$it.key表示原始键名(适用于关联数组)。
五、在volist中调用模板函数处理数组字段
当数组中某字段为序列化字符串、jsON格式或需格式化输出时,可在volist内部直接调用内置函数或自定义函数,无需在控制器中预处理。
1、对json字符串字段解码并取值:
操作详情:{:json_decode($log.params,true)[‘action’]}
2、使用date函数格式化时间戳:
创建时间:{:date(‘Y-m-d H:i’,$log.create_time)}
3、调用自定义函数需先在模板中注册,例如:thinkTemplate::instance()->function(‘format_price’, function($val){ return ‘¥’.sprintf(‘%.2f’,$val); });,然后在volist中使用{:format_price($item.price)}。