#php-angular
仿angularjs的php模板引擎
标签
- php-if php-elseif php-else
- php-for
- php-foreach
- php-repeat
- php-show
- php-hide
- php-include
- php-init
- php-exec
- php-after
- php-before
- php-function
- php-call
- php-switch
- php-case
- php-default
- php-extends
- php-block
变量输出
{$var}
{$array.name}
{$array['name']}
{$var ? '' : ''}
函数调用
{:func()}
具体的框架驱动可以在 https://github.com/php-angular 中找到
此模板引擎针对能够使用angularjs的php开发者编写, 主要特点是 不需要额外的标签定义, 全部使用属性定义, 写好模板文件在IDE中不会出现警告和错误, 格式化代码的时候很整洁, 因为套完的模板文件还是规范的html
注: 一个标签上可以使用多个模板属性, 属性有前后顺序要求, 所以要注意属性的顺序, 在单标签上使用模板属性时一定要使用/>
结束, 如 <input php-if="$is_download" type="button" value="下载" />, <img php-if="$article['pic']" src="{$article.pic}" />
等等, 具体可参考后面章节的解析结果
看云文档托管平台: http://www.kancloud.cn/shuai/php-angular
参考/test目录
<?php
// 配置
$config = [
'debug' => true, // 是否开启调试
'tpl_path' => './view/', // 模板根目录
'tpl_suffix' => '.html', // 模板后缀
'tpl_cache_path' => './cache/', // 模板缓存目录
'tpl_cache_suffix' => '.php', // 模板后缀
'attr' => 'php-', // 标签前缀
'max_tag' => 10000, // 标签的最大解析次数
];
// 实例化
$view = new Angular($config);
// 数据
$data = array(
'title' => 'Hello PHP Angular',
'list' => array(
array('name' => 'name_1', 'email' => 'email_1@qq.com'),
array('name' => 'name_2', 'email' => 'email_2@qq.com'),
array('name' => 'name_3', 'email' => 'email_3@qq.com'),
array('name' => 'name_4', 'email' => 'email_4@qq.com'),
array('name' => 'name_5', 'email' => 'email_5@qq.com'),
),
);
// 向模板引擎设置数据
$view->assign($data);
// 输出解析结果
$view->display('index');
// 获取输出结果
// $view->fetch('index');
<!DOCTYPE html>
<html>
<head>
<title>php-angular</title>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style type="text/css">
.box {
padding: 10px;
font-size: 12px;
margin: 10px 5px;
background: #CCC;
}
</style>
</head>
<body>
<div class="box" php-show="$title">{$title}</div>
<div class="box" php-hide="$title">如果title的值为空, 则可以显示这条消息, 否则不显示</div>
<div class="box">
<span>foreach by [1,2,3,4,5]</span>
<ul>
<li php-foreach="[1,2,3,4,5] as $i">foreach {$i}</li>
</ul>
</div>
<div class="box">
<span>repeat by [1,2,3,4,5]</span>
<ul>
<li php-repeat="[1,2,3,4,5] as $i">foreach {$i}</li>
</ul>
</div>
<div class="box" php-show="$list">
<span>foreach by $list as $item</span>
<ul>
<li php-foreach="$list as $item">name:{$item.name} -- email: {$item.email}</li>
</ul>
</div>
<div class="box" php-show="$list">
<span>repeat by $list as $item</span>
<ul>
<li php-repeat="$list as $item">name:{$item.name} -- email: {$item.email}</li>
</ul>
</div>
<div class="box" php-if="$list">
<span>foreach by $list as $key => $item</span>
<ul>
<li php-foreach="$list as $key => $item">{$key} -- name:{$item.name} -- email: {$item.email}</li>
</ul>
</div>
<div class="box">
<span>for by ($i = 1; $i <= 10; $i++;)</span>
<ul>
<li php-for="$i = 1; $i <= 10; $i++">for {$i}</li>
</ul>
</div>
<div class="box" php-if="$list">
<span>$list 不为空</span>
</div>
</body>
</html>
<!DOCTYPE html>
<html>
<head>
<title>php-angular</title>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style type="text/css">
.box {
padding: 10px;
font-size: 12px;
margin: 10px 5px;
background: #CCC;
}
</style>
</head>
<body>
<?php if ($title) { ?><div class="box" ><?php echo $title; ?></div><?php } ?>
<?php if (!($title)) { ?><div class="box" >如果title的值为空, 则可以显示这条消息, 否则不显示</div><?php } ?>
<div class="box">
<span>foreach by [1,2,3,4,5]</span>
<ul>
<?php foreach ([1,2,3,4,5] as $i) { ?><li >foreach <?php echo $i; ?></li><?php } ?>
</ul>
</div>
<div class="box">
<span>repeat by [1,2,3,4,5]</span>
<ul>
<?php foreach ([1,2,3,4,5] as $i) { ?><li >foreach <?php echo $i; ?></li><?php } ?>
</ul>
</div>
<?php if ($list) { ?><div class="box" >
<span>foreach by $list as $item</span>
<ul>
<?php foreach ($list as $item) { ?><li >name:<?php echo $item["name"]; ?> -- email: <?php echo $item["email"]; ?></li><?php } ?>
</ul>
</div><?php } ?>
<?php if ($list) { ?><div class="box" >
<span>repeat by $list as $item</span>
<ul>
<?php foreach ($list as $item) { ?><li >name:<?php echo $item["name"]; ?> -- email: <?php echo $item["email"]; ?></li><?php } ?>
</ul>
</div><?php } ?>
<?php if ($list) { ?><div class="box" >
<span>foreach by $list as $key => $item</span>
<ul>
<?php foreach ($list as $key => $item) { ?><li ><?php echo $key; ?> -- name:<?php echo $item["name"]; ?> -- email: <?php echo $item["email"]; ?></li><?php } ?>
</ul>
</div><?php } ?>
<div class="box">
<span>for by ($i = 1; $i <= 10; $i++;)</span>
<ul>
<?php for ($i = 1; $i <= 10; $i++) { ?><li >for <?php echo $i; ?></li><?php } ?>
</ul>
</div>
<?php if ($list) { ?><div class="box" >
<span>$list 不为空</span>
</div><?php } ?>
</body>
</html>