tp如何将控制器里的数组放到html里

8次阅读

thinkphp 模板中显示控制器传来的数组需用 {volist} 或{foreach}遍历,关联数组用{$data.name},数字索引用{$data.0};二维数组需确认字段名大小写及是否为空;json 数据须加 |raw 避免转义。

tp 如何将控制器里的数组放到 html 里

tp 模板里怎么显示控制器传来的数组

ThinkPHP 默认用 assign() 把变量传给模板,数组也不例外。关键不是“能不能传”,而是传过去之后在模板里怎么安全、准确地取出来——尤其是嵌套数组或含空值的情况容易出错。

  • 控制器里必须用 $this->assign('data', $array),不能写成 $this->assign($array)(少个键名会丢数据)
  • 模板里直接用 {$data} 只会输出字符串(比如 Array),得用 {volist}{foreach} 遍历
  • 如果数组是关联的(比如 ['name' => '张三', 'age' => 25]),模板里写 {$data.name} 没问题;但如果是数字索引([0 => 'a', 1 => 'b']),就得用 {$data.0} 或进循环

volist 标签遍历二维数组总报错 Undefined index

常见于从数据库查出来的 $list = Db::name('user')->select() 这种结果集,直接 {volist name="list" id="vo"} 是对的,但里面写 {$vo.username} 却报错,大概率是字段名大小写不一致或者查了空数组。

  • 先确认控制器里 dump($list) 看真实结构:TP6 的 select() 返回的是对象数组,不是纯数组,字段名默认小写,但数据库字段如果是 user_name,PHP 里就是 $vo['user_name'],不是 $vo.userName
  • {volist}name 值必须和 assign() 的键名完全一致,区分大小写
  • 空数组时 {volist} 不渲染内容,不会报错;但如果你在它外面写了 {$list.0.username} 就会崩,别这么干

模板里想用 PHP 原生语法读数组行不行

可以,但要关掉模板引擎的标签解析,而且不推荐。TP 默认开启 tpl_deny_php,直接写 <?php echo $data[0]['name']; ?> 会被拦截,报错 Parse error: syntax error, unexpected '

  • 临时启用 PHP 代码需在配置里设 'tpl_deny_php' => false,但线上环境严禁打开,有安全风险
  • 更稳妥的做法是:复杂逻辑提前在控制器处理好,比如把二维数组转成一维映射,再传给模板
  • 真要动态取值,用 {php}echo $data[0]['name'];{/php} —— 注意这是 TP 自定义标签,不是原生 PHP,且只在老版本(5.x)支持,TP6 已移除

json_encode 后前端拿不到数据

有人把数组 json_encode() 后用 assign() 传过去,模板里写 {$json_data},结果前端 JS 里 JSON.parse() 失败。问题出在模板自动转义和引号嵌套上。

立即学习 前端免费学习笔记(深入)”;

  • 模板默认对变量做 HTML 转义,{" 全被转成实体字符,JS 拿到的是乱码
  • 正确做法是:{:htmlspecialchars_decode($json_data)} 或更干净的 {:$json_data|raw}
  • 但最省心的是别在模板里拼 JSON:控制器里用 $this->assign('data', json_encode($array)),模板里写 <script>var data = {:json_encode($array)|raw};</script>,注意 |raw 必须加,不然白搭
传数组本身不难,难的是传完之后模板里怎么不踩空、不转义、不混淆索引类型。尤其注意 TP6 对对象数组的处理方式和老版本不同,查库结果别想当然当普通数组用。

text=ZqhQzanResources